2021-01-29 00:20:46 +05:30
---
stage: Configure
group: Configure
2021-02-22 17:27:13 +05:30
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments
2021-01-29 00:20:46 +05:30
---
2020-06-23 00:09:42 +05:30
# Requirements for Auto DevOps
2021-02-22 17:27:13 +05:30
You can set up Auto DevOps for [Kubernetes ](#auto-devops-requirements-for-kubernetes ),
[Amazon Elastic Container Service (ECS) ](#auto-devops-requirements-for-amazon-ecs ),
or [Amazon Cloud Compute ](#auto-devops-requirements-for-amazon-ecs ).
2020-06-23 00:09:42 +05:30
For more information about Auto DevOps, see [the main Auto DevOps page ](index.md )
or the [quick start guide ](quick_start_guide.md ).
## Auto DevOps requirements for Kubernetes
To make full use of Auto DevOps with Kubernetes, you need:
- **Kubernetes** (for [Auto Review Apps ](stages.md#auto-review-apps ),
[Auto Deploy ](stages.md#auto-deploy ), and [Auto Monitoring ](stages.md#auto-monitoring ))
To enable deployments, you need:
1. A [Kubernetes 1.12+ cluster ](../../user/project/clusters/index.md ) for your
project. The easiest way is to create a
[new cluster using the GitLab UI ](../../user/project/clusters/add_remove_clusters.md#create-new-cluster ).
For Kubernetes 1.16+ clusters, you must perform additional configuration for
[Auto Deploy for Kubernetes 1.16+ ](stages.md#kubernetes-116 ).
1. NGINX Ingress. You can deploy it to your Kubernetes cluster by installing
the [GitLab-managed app for Ingress ](../../user/clusters/applications.md#ingress ),
2021-02-22 17:27:13 +05:30
after configuring the GitLab integration with Kubernetes in the previous step.
2020-06-23 00:09:42 +05:30
Alternatively, you can use the
[`nginx-ingress` ](https://github.com/helm/charts/tree/master/stable/nginx-ingress )
Helm chart to install Ingress manually.
2021-02-22 17:27:13 +05:30
NOTE:
If you use your own Ingress instead of the one provided by GitLab Managed
Apps, ensure you're running at least version 0.9.0 of NGINX Ingress and
2020-06-23 00:09:42 +05:30
[enable Prometheus metrics ](https://github.com/helm/charts/tree/master/stable/nginx-ingress#prometheus-metrics )
for the response metrics to appear. You must also
[annotate ](https://kubernetes.io/docs/concepts/overview/working-with-objects/annotations/ )
the NGINX Ingress deployment to be scraped by Prometheus using
`prometheus.io/scrape: "true"` and `prometheus.io/port: "10254"` .
- **Base domain** (for [Auto Review Apps ](stages.md#auto-review-apps ),
[Auto Deploy ](stages.md#auto-deploy ), and [Auto Monitoring ](stages.md#auto-monitoring ))
You need a domain configured with wildcard DNS, which all of your Auto DevOps
2021-02-22 17:27:13 +05:30
applications use. If you're using the
2020-06-23 00:09:42 +05:30
[GitLab-managed app for Ingress ](../../user/clusters/applications.md#ingress ),
the URL endpoint is automatically configured for you.
You must also [specify the Auto DevOps base domain ](index.md#auto-devops-base-domain ).
- **GitLab Runner** (for all stages)
2020-11-24 15:15:51 +05:30
Your runner must be configured to run Docker, usually with either the
2020-06-23 00:09:42 +05:30
[Docker ](https://docs.gitlab.com/runner/executors/docker.html )
or [Kubernetes ](https://docs.gitlab.com/runner/executors/kubernetes.html ) executors, with
[privileged mode enabled ](https://docs.gitlab.com/runner/executors/docker.html#use-docker-in-docker-with-privileged-mode ).
2020-11-24 15:15:51 +05:30
The runners don't need to be installed in the Kubernetes cluster, but the
2020-06-23 00:09:42 +05:30
Kubernetes executor is easy to use and automatically autoscales.
2020-11-24 15:15:51 +05:30
You can configure Docker-based runners to autoscale as well, using
2020-06-23 00:09:42 +05:30
[Docker Machine ](https://docs.gitlab.com/runner/install/autoscaling.html ).
2021-02-22 17:27:13 +05:30
If you've configured the GitLab integration with Kubernetes in the first step, you
2020-06-23 00:09:42 +05:30
can deploy it to your cluster by installing the
[GitLab-managed app for GitLab Runner ](../../user/clusters/applications.md#gitlab-runner ).
2020-11-24 15:15:51 +05:30
Runners should be registered as [shared runners ](../../ci/runners/README.md#shared-runners )
for the entire GitLab instance, or [specific runners ](../../ci/runners/README.md#specific-runners )
2020-06-23 00:09:42 +05:30
that are assigned to specific projects (the default if you've installed the
GitLab Runner managed application).
- **Prometheus** (for [Auto Monitoring ](stages.md#auto-monitoring ))
To enable Auto Monitoring, you need Prometheus installed either inside or
outside your cluster, and configured to scrape your Kubernetes cluster.
2021-02-22 17:27:13 +05:30
If you've configured the GitLab integration with Kubernetes, you can deploy it to
2020-06-23 00:09:42 +05:30
your cluster by installing the
[GitLab-managed app for Prometheus ](../../user/clusters/applications.md#prometheus ).
The [Prometheus service ](../../user/project/integrations/prometheus.md )
integration must be enabled for the project, or enabled as a
[default service template ](../../user/project/integrations/services_templates.md )
for the entire GitLab installation.
To get response metrics (in addition to system metrics), you must
[configure Prometheus to monitor NGINX ](../../user/project/integrations/prometheus_library/nginx_ingress.md#configuring-nginx-ingress-monitoring ).
- **cert-manager** (optional, for TLS/HTTPS)
To enable HTTPS endpoints for your application, you must install cert-manager,
a native Kubernetes certificate management controller that helps with issuing
certificates. Installing cert-manager on your cluster issues a
[Let’ s Encrypt ](https://letsencrypt.org/ ) certificate and ensures the
2021-02-22 17:27:13 +05:30
certificates are valid and up-to-date. If you've configured the GitLab integration
with Kubernetes, you can deploy it to your cluster by installing the
2020-06-23 00:09:42 +05:30
[GitLab-managed app for cert-manager ](../../user/clusters/applications.md#cert-manager ).
If you don't have Kubernetes or Prometheus installed, then
[Auto Review Apps ](stages.md#auto-review-apps ),
[Auto Deploy ](stages.md#auto-deploy ), and [Auto Monitoring ](stages.md#auto-monitoring )
are skipped.
After all requirements are met, you can [enable Auto DevOps ](index.md#enablingdisabling-auto-devops ).
## Auto DevOps requirements for Amazon ECS
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/208132) in GitLab 13.0.
2020-07-28 23:09:34 +05:30
You can choose to target [AWS ECS ](../../ci/cloud_deployment/index.md ) as a deployment platform instead of using Kubernetes.
2020-06-23 00:09:42 +05:30
2021-02-22 17:27:13 +05:30
To get started on Auto DevOps to AWS ECS, you must add a specific Environment
2020-06-23 00:09:42 +05:30
Variable. To do so, follow these steps:
1. In your project, go to **Settings > CI / CD** and expand the **Variables**
section.
1. Specify which AWS platform to target during the Auto DevOps deployment
2020-07-28 23:09:34 +05:30
by adding the `AUTO_DEVOPS_PLATFORM_TARGET` variable with one of the following values:
- `FARGATE` if the service you're targeting must be of launch type FARGATE.
- `ECS` if you're not enforcing any launch type check when deploying to ECS.
2020-06-23 00:09:42 +05:30
2020-07-28 23:09:34 +05:30
When you trigger a pipeline, if you have Auto DevOps enabled and if you have correctly
2020-06-23 00:09:42 +05:30
[entered AWS credentials as environment variables ](../../ci/cloud_deployment/index.md#deploy-your-application-to-the-aws-elastic-container-service-ecs ),
2021-02-22 17:27:13 +05:30
your application is deployed to AWS ECS.
2020-07-28 23:09:34 +05:30
[GitLab Managed Apps ](../../user/clusters/applications.md ) are not available when deploying to AWS ECS.
You must manually configure your application (such as Ingress or Help) on AWS ECS.
2020-06-23 00:09:42 +05:30
If you have both a valid `AUTO_DEVOPS_PLATFORM_TARGET` variable and a Kubernetes cluster tied to your project,
2021-02-22 17:27:13 +05:30
only the deployment to Kubernetes runs.
2020-06-23 00:09:42 +05:30
2021-02-22 17:27:13 +05:30
WARNING:
Setting the `AUTO_DEVOPS_PLATFORM_TARGET` variable to `ECS` triggers jobs
2020-06-23 00:09:42 +05:30
defined in the [`Jobs/Deploy/ECS.gitlab-ci.yml` template ](https://gitlab.com/gitlab-org/gitlab/-/blob/master/lib/gitlab/ci/templates/Jobs/Deploy/ECS.gitlab-ci.yml ).
However, it's not recommended to [include ](../../ci/yaml/README.md#includetemplate )
it on its own. This template is designed to be used with Auto DevOps only. It may change
unexpectedly causing your pipeline to fail if included on its own. Also, the job
2020-07-28 23:09:34 +05:30
names within this template may also change. Do not override these jobs' names in your
2021-02-22 17:27:13 +05:30
own pipeline, as the override stops working when the name changes.
## Auto DevOps requirements for Amazon EC2
[Introduced ](https://gitlab.com/gitlab-org/gitlab/-/issues/216008 ) in GitLab 13.6.
You can target [AWS EC2 ](../../ci/cloud_deployment/index.md )
as a deployment platform instead of Kubernetes. To use Auto DevOps with AWS EC2, you must add a
specific environment variable.
For more details, see [Custom build job for Auto DevOps ](../../ci/cloud_deployment/index.md#custom-build-job-for-auto-devops )
for deployments to AWS EC2.