quick_start_guide.md 5.25 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
# Auto DevOps: quick start guide

> [Introduced][ce-37115] in GitLab 10.0. Auto DevOps is currently in Beta and
**not recommended for production use**.

This is a step-by-step guide to deploying a project hosted on GitLab.com to
Google Cloud, using Auto DevOps.

We made a minimal [Ruby
application](https://gitlab.com/gitlab-examples/minimal-ruby-app) to use as an
example for this guide. It contains two files:

* `server.rb` - our application. It will start an HTTP server on port 5000 and
  render "Hello, world!"
* `Dockerfile` - to build our app into a container image. It will use a ruby
  base image and run `server.rb`

## Fork sample project on GitLab.com

Let’s start by forking our sample application. Go to [the project
21 22 23
page](https://gitlab.com/auto-devops-examples/minimal-ruby-app) and press the
**Fork** button. Soon you should have a project under your namespace with the
necessary files.
24 25 26

## Setup your own cluster on Google Container Engine

27 28
If you do not already have a Google Cloud account, create one at
https://console.cloud.google.com.
29

30 31 32 33
Visit the [**Container Engine**](https://console.cloud.google.com/kubernetes/list)
tab and create a new cluster. You can change the name and leave the rest of the
default settings. Once you have your cluster running, you need to connect to the
cluster by following the Google interface.
34 35 36 37

## Connect to Kubernetes cluster

You need to have the Google Cloud SDK installed. e.g.
38
On macOS, install [homebrew](https://brew.sh):
39 40 41

1. Install Brew Caskroom: `brew install caskroom/cask/brew-cask`
2. Install Google Cloud SDK: `brew cask install google-cloud-sdk`
42
3. Add `kubectl` with: `gcloud components install kubectl`
43 44
4. Log in: `gcloud auth login`

45 46 47 48 49 50 51 52 53
Now go back to the Google interface, find your cluster, follow the instructions
under "Connect to the cluster" and open the Kubernetes Dashboard. It will look
something like:

```sh
gcloud container clusters get-credentials ruby-autodeploy \ --zone europe-west2-c --project api-project-XXXXXXX
```

Finally, run `kubectl proxy`.
54 55 56 57 58

![connect to cluster](img/guide_connect_cluster.png)

## Copy credentials to GitLab.com project

59 60 61
Once you have the Kubernetes Dashboard interface running, you should visit
**Secrets** under the  "Config" section. There, you should find the settings we
need for GitLab integration: `ca.crt` and token.
62 63 64

![connect to cluster](img/guide_secret.png)

65 66 67 68 69
You need to copy-paste the `ca.crt` and token into your project on GitLab.com in
the Kubernetes integration page under project
**Settings > Integrations > Project services > Kubernetes**. Don't actually copy
the namespace though. Each project should have a unique namespace, and by leaving
it blank, GitLab will create one for you.
70 71 72

![connect to cluster](img/guide_integration.png)

73 74
For the API URL, you should use the "Endpoint" IP from your cluster page on
Google Cloud Platform.
75 76 77

## Expose application to the world

78 79 80
In order to be able to visit your application, you need to install an NGINX
ingress controller and point your domain name to its external IP address. Let's
see how that's done.
81 82 83 84 85 86 87 88 89 90 91

### Set up Ingress controller

You’ll need to make sure you have an ingress controller. If you don’t have one, do:

```sh
brew install kubernetes-helm
helm init
helm install --name ruby-app stable/nginx-ingress
```

92 93
This should create several services including `ruby-app-nginx-ingress-controller`.
You can list your services by running `kubectl get svc` to confirm that.
94 95 96

### Point DNS at Cluster IP

97 98
Find out the external IP address of the `ruby-app-nginx-ingress-controller` by
running:
99 100 101 102 103

```sh
kubectl get svc ruby-app-nginx-ingress-controller -o jsonpath='{.status.loadBalancer.ingress[0].ip}'
```

104 105 106
Use this IP address to configure your DNS. This part heavily depends on your
preferences and domain provider. But in case you are not sure, just create an
A record with a wildcard host like `*.<your-domain>`.
107

108 109
Use `nslookup minimal-ruby-app-staging.<yourdomain>` to confirm that domain is
assigned to the cluster IP.
110 111 112

## Set up Auto DevOps

113 114
In your GitLab.com project, go to **Settings > CI/CD** and find the Auto DevOps
section. Select "Enable Auto DevOps", add in your base domain, and save.
115 116 117

![auto devops settings](img/auto_devops_settings.png)

118 119 120 121 122 123 124 125 126 127 128 129 130 131 132
Next, a pipeline needs to be triggered. Since the test project doesn't have a
`.gitlab-ci.yml`, you need to either push a change to the repository or
manually visit `https://gitlab.com/<username>/minimal-ruby-app/pipelines/run`,
where `<username>` is your username.

This will create a new pipeline with several jobs: `build`, `test`, `codequality`,
and `production`. The `build` job will create a Docker image with your new
change and push it to the Container Registry. The `test` job will test your
changes, whereas the `codequality` job will run static analysis on your changes.
Finally, the `production` job will deploy your changes to a production application.

Once the deploy job succeeds you should be able to see your application by
visiting the Kubernetes dashboard. Select the namespace of your project, which
will look like `minimal-ruby-app-23`, but with a unique ID for your project,
and your app will be listed as "production" under the Deployment tab.
133

134 135
Once its ready, just visit `http://minimal-ruby-app.example.com` to see the
famous "Hello, world!"!
136 137

[ce-37115]: https://gitlab.com/gitlab-org/gitlab-ce/issues/37115