231 lines
9.8 KiB
Markdown
231 lines
9.8 KiB
Markdown
---
|
|
stage: Configure
|
|
group: Configure
|
|
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/product/ux/technical-writing/#assignments
|
|
---
|
|
|
|
# Auto DevOps **(FREE)**
|
|
|
|
> - [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/issues/38366) in GitLab 11.0.
|
|
> - Support for the GitLab agent was [introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/299350) in GitLab 14.5.
|
|
|
|
GitLab Auto DevOps is a collection of pre-configured features and integrations
|
|
that work together to support your software delivery process.
|
|
|
|
Auto DevOps detects your programming language and uses [CI/CD templates](https://gitlab.com/gitlab-org/gitlab/-/tree/master/lib/gitlab/ci/templates)
|
|
to create and run default pipelines to build and test your application. Then, you can [configure deployments](requirements.md) to deploy your apps to staging
|
|
and production, and set up [Review Apps](stages.md#auto-review-apps)
|
|
to preview your changes per branch.
|
|
|
|
You can use default settings to quickly ship your apps, and iterate and [customize](customize.md) later.
|
|
|
|
You can also [manage Auto DevOps with APIs](customize.md#extend-auto-devops-with-the-api).
|
|
|
|
<i class="fa fa-youtube-play youtube" aria-hidden="true"></i>
|
|
For an introduction to Auto DevOps, watch [Auto DevOps in GitLab 11.0](https://youtu.be/0Tc0YYBxqi4).
|
|
|
|
## Auto DevOps features
|
|
|
|
Auto DevOps supports development during each of the [DevOps stages](stages.md).
|
|
|
|
| Stage | Auto DevOps feature |
|
|
|---------|-------------|
|
|
| Build | [Auto Build](stages.md#auto-build) |
|
|
| Build | [Auto Dependency Scanning](stages.md#auto-dependency-scanning) |
|
|
| Test | [Auto Test](stages.md#auto-test) |
|
|
| Test | [Auto Browser Performance Testing](stages.md#auto-browser-performance-testing) |
|
|
| Test | [Auto Code Intelligence](stages.md#auto-code-intelligence) |
|
|
| Test | [Auto Code Quality](stages.md#auto-code-quality) |
|
|
| Test | [Auto Container Scanning](stages.md#auto-container-scanning) |
|
|
| Test | [Auto License Compliance](stages.md#auto-license-compliance) |
|
|
| Deploy | [Auto Review Apps](stages.md#auto-review-apps) |
|
|
| Deploy | [Auto Deploy](stages.md#auto-deploy) |
|
|
| Monitor | [Auto Monitoring](stages.md#auto-monitoring) |
|
|
| Secure | [Auto Dynamic Application Security Testing (DAST)](stages.md#auto-dast) |
|
|
| Secure | [Auto Static Application Security Testing (SAST)](stages.md#auto-sast) |
|
|
| Secure | [Auto Secret Detection](stages.md#auto-secret-detection) |
|
|
|
|
### Comparison to application platforms and PaaS
|
|
|
|
Auto DevOps provides features often included in an application
|
|
platform or in a Platform as a Service (PaaS).
|
|
|
|
Inspired by [Heroku](https://www.heroku.com/), Auto DevOps goes beyond it
|
|
in multiple ways:
|
|
|
|
- Auto DevOps works with any Kubernetes cluster.
|
|
- There is no additional cost.
|
|
- You can use a cluster hosted by yourself or on any public cloud.
|
|
- Auto DevOps offers an incremental graduation path. If you need to [customize](customize.md), start by changing the templates and evolve from there.
|
|
|
|
## Get started with Auto DevOps
|
|
|
|
To get started, you only need to [enable Auto DevOps](#enable-or-disable-auto-devops).
|
|
This is enough to run an Auto DevOps pipeline to build and
|
|
test your application.
|
|
|
|
If you want to build, test, and deploy your app:
|
|
|
|
1. View the [requirements for deployment](requirements.md).
|
|
1. [Enable Auto DevOps](#enable-or-disable-auto-devops).
|
|
1. [Deploy your app to a cloud provider](#deploy-your-app-to-a-cloud-provider).
|
|
|
|
### Enable or disable Auto DevOps
|
|
|
|
> - [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/issues/41729) in GitLab 11.3, Auto DevOps is enabled by default.
|
|
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/26655) in GitLab 12.7, Auto DevOps runs pipelines automatically only if a [`Dockerfile` or matching buildpack](stages.md#auto-build) exists.
|
|
|
|
Depending on your instance type, you can enable or disable Auto DevOps at the
|
|
following levels:
|
|
|
|
| Instance type | [Project](#at-the-project-level) | [Group](#at-the-group-level) | [Instance](#at-the-instance-level) (Admin Area) |
|
|
|---------------------|------------------------|------------------------|------------------------|
|
|
| GitLab SaaS | **{check-circle}** Yes | **{check-circle}** Yes | **{dotted-circle}** No |
|
|
| GitLab self-managed | **{check-circle}** Yes | **{check-circle}** Yes | **{check-circle}** Yes |
|
|
|
|
Before enabling Auto DevOps, consider [preparing it for deployment](requirements.md). If you don't, Auto DevOps can build and test your app,
|
|
but cannot deploy it.
|
|
|
|
#### At the project level
|
|
|
|
To use Auto DevOps for individual projects, you can enable it in a
|
|
project-by-project basis. If you intend to use it for more projects,
|
|
you can enable it for a [group](#at-the-group-level) or an
|
|
[instance](#at-the-instance-level). This can save you the time of
|
|
enabling it in each project.
|
|
|
|
Prerequisites:
|
|
|
|
- You must have at least the Maintainer role for the project.
|
|
- Ensure your project does not have a `.gitlab-ci.yml` present. If present, your CI/CD configuration takes
|
|
precedence over the Auto DevOps pipeline.
|
|
|
|
To enable Auto DevOps for a project:
|
|
|
|
1. On the top bar, select **Main menu > Projects** and find your project.
|
|
1. On the left sidebar, select **Settings > CI/CD**.
|
|
1. Expand **Auto DevOps**.
|
|
1. Select the **Default to Auto DevOps pipeline** checkbox.
|
|
1. Optional but recommended. Add the [base domain](requirements.md#auto-devops-base-domain).
|
|
1. Optional but recommended. Choose the [deployment strategy](requirements.md#auto-devops-deployment-strategy).
|
|
1. Select **Save changes**.
|
|
|
|
GitLab triggers the Auto DevOps pipeline on the default branch.
|
|
|
|
To disable it, follow the same process and clear the
|
|
**Default to Auto DevOps pipeline** checkbox.
|
|
|
|
#### At the group level
|
|
|
|
> [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/issues/52447) in GitLab 11.10.
|
|
|
|
When you enable Auto DevOps at the group level, the subgroups and
|
|
projects in that group inherit the configuration. You can save time by
|
|
enabling Auto DevOps for a group instead of enabling it for each
|
|
subgroup or project.
|
|
|
|
When enabled for a group, you can still disable Auto DevOps
|
|
for the subgroups and projects where you don't want to use it.
|
|
|
|
Prerequisites:
|
|
|
|
- You must have the Owner role for the group.
|
|
|
|
To enable Auto DevOps for a group:
|
|
|
|
1. On the top bar, select **Main menu > Groups** and find your group.
|
|
1. On the left sidebar, select **Settings > CI/CD**.
|
|
1. Expand **Auto DevOps**.
|
|
1. Select the **Default to Auto DevOps pipeline** checkbox.
|
|
1. Select **Save changes**.
|
|
|
|
To disable Auto DevOps at the group level, follow the same process and
|
|
clear the **Default to Auto DevOps pipeline** checkbox.
|
|
|
|
After enabling Auto DevOps at the group level, you can trigger the
|
|
Auto DevOps pipeline for any project that belongs to that group:
|
|
|
|
1. On the top bar, select **Main menu > Projects** and find your project.
|
|
1. Make sure the project doesn't contain a `.gitlab-ci.yml` file.
|
|
1. On the left sidebar, select **CI/CD > Pipelines**.
|
|
1. To trigger the Auto DevOps pipeline, select **Run pipeline**.
|
|
|
|
#### At the instance level **(FREE SELF)**
|
|
|
|
To enable Auto DevOps by default for all projects, you can enable it at the instance level.
|
|
You can still disable Auto DevOps for each group and project
|
|
where you don't want to run it.
|
|
|
|
Even when disabled for an instance, group Owners and project Maintainers
|
|
can still enable Auto DevOps at the group and project levels.
|
|
|
|
Prerequisites:
|
|
|
|
- You must be an administrator for the instance.
|
|
|
|
To enable Auto DevOps for your instance:
|
|
|
|
1. On the top bar, select **Main menu > Admin**.
|
|
1. On the left sidebar, select **Settings > CI/CD**.
|
|
1. Expand **Auto DevOps**.
|
|
1. Select the **Default to Auto DevOps pipeline** checkbox.
|
|
1. Optional. Add the Auto DevOps [base domain](requirements.md#auto-devops-base-domain).
|
|
1. Select **Save changes**.
|
|
|
|
When enabled, Auto DevOps attempts to run pipelines in every project. If the
|
|
pipeline fails in a particular project, it disables itself.
|
|
GitLab administrators can change this in the [Auto DevOps settings](../../user/admin_area/settings/continuous_integration.md#auto-devops).
|
|
|
|
If a [CI/CD configuration file](../../ci/yaml/index.md) is present,
|
|
it remains unchanged and Auto DevOps does not affect it.
|
|
|
|
To disable Auto DevOps in the instance level, follow the same process
|
|
and clear the **Default to Auto DevOps pipeline** checkbox.
|
|
|
|
### Deploy your app to a cloud provider
|
|
|
|
- [Use Auto DevOps to deploy to a Kubernetes cluster on Google Kubernetes Engine (GKE)](cloud_deployments/auto_devops_with_gke.md)
|
|
- [Use Auto DevOps to deploy to EC2](cloud_deployments/auto_devops_with_ec2.md)
|
|
- [Use Auto DevOps to deploy to ECS](cloud_deployments/auto_devops_with_ecs.md)
|
|
|
|
## Upgrade Auto DevOps dependencies when updating GitLab
|
|
|
|
When updating GitLab, you might need to upgrade Auto DevOps dependencies to
|
|
match your new GitLab version:
|
|
|
|
- [Upgrading Auto DevOps resources](upgrading_auto_deploy_dependencies.md):
|
|
- Auto DevOps template.
|
|
- Auto Deploy template.
|
|
- Auto Deploy image.
|
|
- Helm.
|
|
- Kubernetes.
|
|
- Environment variables.
|
|
- [Upgrading PostgreSQL](upgrading_postgresql.md).
|
|
|
|
## Private registry support
|
|
|
|
There is no guarantee that you can use a private container registry with Auto DevOps.
|
|
|
|
Instead, use the [GitLab Container Registry](../../user/packages/container_registry/index.md) with Auto DevOps to
|
|
simplify configuration and prevent any unforeseen issues.
|
|
|
|
## Install applications behind a proxy
|
|
|
|
The GitLab integration with Helm does not support installing applications when
|
|
behind a proxy.
|
|
|
|
If you want to do so, you must inject proxy settings into the
|
|
installation pods at runtime.
|
|
|
|
## Related topics
|
|
|
|
- [Continuous methodologies](../../ci/introduction/index.md)
|
|
- [Docker](https://docs.docker.com)
|
|
- [GitLab Runner](https://docs.gitlab.com/runner/)
|
|
- [Helm](https://helm.sh/docs/)
|
|
- [Kubernetes](https://kubernetes.io/docs/home/)
|
|
- [Prometheus](https://prometheus.io/docs/introduction/overview/)
|
|
|
|
## Troubleshooting
|
|
|
|
See [troubleshooting Auto DevOps](troubleshooting.md).
|