#+TITLE: Gitlab GCP Deployment #+AUTHOR: James Blair #+EMAIL: mail@jamesblair.net #+DATE: 5th January 2021 This org file is intended to capture and automate the end to end workflow to deploy an instance of [[https://gitlab.com][Gitlab]] on [[https://console.cloud.google.com][Google Cloud Platform]]. We'll use shell blocks inside this file which can be executed with [[https://orgmode.org/worg/org-contrib/babel/][Babel]]. Additionally we want to explore tangling these source code blocks to shell script files within this document so that the scripts can then be executed by a continous delivery pipeline. *Notes:* 1. To interact with this org file we're using the [[https://github.com/humacs/humacs][Humacs]] distribution of [[https://www.gnu.org/software/emacs/][Emacs]]. 1. This workflow has only been tested on the ~Ubuntu 20.04~ linux distribution, via [[https://ubuntu.com/wsl][WSL 2]]. * Step 1 - Ensure GCP SDK is installed To automate our interactions with Google Cloud Platform we'll use the [[https://cloud.google.com/sdk/docs/install#deb][GCP SDK]] which provides us with a number of command line tools to interact with the platform, such as ~gcloud~, ~gsutil~ and ~kubectl~. Tangle the shell block below to a shell script by pressing *, b t* in emacs command mode: #+NAME: Install google cloud sdk #+BEGIN_SRC bash :shebang #!/bin/bash :tangle 1-install-gcp-sdk.sh # Add the Cloud SDK distribution URI as a package source echo "deb [signed-by=/usr/share/keyrings/cloud.google.gpg] https://packages.cloud.google.com/apt cloud-sdk main" | sudo tee /etc/apt/sources.list.d/google-cloud-sdk.list # Make sure apt-transport-https is installed sudo apt-get install -y apt-transport-https ca-certificates gnupg # Import the Google Cloud public key curl https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key --keyring /usr/share/keyrings/cloud.google.gpg add - # Update and install the SDK sudo apt-get update && sudo apt-get install -y google-cloud-sdk #+END_SRC * Step 2 - Configure Google Cloud Platform resources With GCP SDK now installed we need to authenticate, create a project and then create a virtual machine instance that we will install Gitlab into later in the workflow. First up is authentication so our GCP SDK installation can carry out actions in a given account and project. This part of the process is currently a manual step as the authentication process includes some interactive steps. In future we could automate this process as part of a continous delivery pipeline using a GCP service account with permission to create virtual machine instances. #+NAME: Authenticate with google cloud platform #+BEGIN_SRC bash :shebang #!/bin/bash :tangle no gcloud auth login #+END_SRC Once we have authenticated we can create a project and then create a new virtual machine instance within that project.