2021-01-29 00:20:46 +05:30
---
2023-06-20 00:43:36 +05:30
stage: Deploy
group: Environments
2022-11-25 23:54:43 +05:30
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
2021-01-29 00:20:46 +05:30
---
2023-03-17 16:20:25 +05:30
# Customize Auto DevOps **(FREE)**
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
You can customize components of Auto DevOps to fit your needs. For example, you can:
- Add custom [buildpacks ](#custom-buildpacks ), [Dockerfiles ](#custom-dockerfiles ), and [Helm charts ](#custom-helm-chart ).
- Enable staging and canary deployments with a custom [CI/CD configuration ](#customize-gitlab-ciyml ).
- Extend Auto DevOps with the [GitLab API ](#extend-auto-devops-with-the-api ).
## Auto DevOps banner
When Auto DevOps is not enabled, a banner displays for users with at
least the Maintainer role:
![Auto DevOps banner ](img/autodevops_banner_v12_6.png )
The banner can be disabled for:
- A user, when they dismiss it themselves.
- A project, by explicitly [disabling Auto DevOps ](index.md#enable-or-disable-auto-devops ).
- An entire GitLab instance:
- By an administrator running the following in a Rails console:
```ruby
Feature.enable(:auto_devops_banner_disabled)
```
- Through the REST API with an administrator access token:
```shell
curl --data "value=true" --header "PRIVATE-TOKEN: < personal_access_token > " "https://gitlab.example.com/api/v4/features/auto_devops_banner_disabled"
```
2020-04-22 19:07:51 +05:30
## Custom buildpacks
2023-03-17 16:20:25 +05:30
You can customize your buildpacks when either:
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
- The automatic buildpack detection fails for your project.
- You need more control over your build.
### Customize buildpacks with Cloud Native Buildpacks
2021-09-04 01:27:46 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/28165) in GitLab 12.10.
Specify either:
2022-07-16 23:28:13 +05:30
- The CI/CD variable `BUILDPACK_URL` with any of [`pack`'s URI specification formats ](https://buildpacks.io/docs/app-developer-guide/specify-buildpacks/ ).
2021-09-04 01:27:46 +05:30
- A [`project.toml` project descriptor ](https://buildpacks.io/docs/app-developer-guide/using-project-descriptor/ ) with the buildpacks you would like to include.
2023-04-23 21:23:45 +05:30
<!-- - start_remove The following content will be removed on remove_date: '2024 - 08 - 22' -->
### Customize buildpacks with Herokuish (deprecated)
WARNING:
Support for Herokuish was [deprecated ](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/108234 ) in GitLab 15.8,
and is planned for removal in 17.0. Use [Cloud Native Buildpacks ](stages.md#moving-from-herokuish-to-cloud-native-buildpacks ) instead.
2021-09-04 01:27:46 +05:30
Specify either:
- The CI/CD variable `BUILDPACK_URL` .
2023-03-17 16:20:25 +05:30
- A `.buildpacks` file at the root of your project that contains one buildpack URL per line.
2020-04-22 19:07:51 +05:30
The buildpack URL can point to either a Git repository URL or a tarball URL.
2023-03-17 16:20:25 +05:30
For Git repositories, you can point to a specific Git reference by
appending `#<ref>` to the Git repository URL. For example, you can
reference:
2020-04-22 19:07:51 +05:30
- The tag `v142` : `https://github.com/heroku/heroku-buildpack-ruby.git#v142` .
- The branch `mybranch` : `https://github.com/heroku/heroku-buildpack-ruby.git#mybranch` .
- The commit SHA `f97d8a8ab49` : `https://github.com/heroku/heroku-buildpack-ruby.git#f97d8a8ab49` .
2023-04-23 21:23:45 +05:30
<!-- - end_remove -->
2020-04-22 19:07:51 +05:30
### Multiple buildpacks
2023-03-17 16:20:25 +05:30
Because Auto Test cannot use the `.buildpacks` file, Auto DevOps does
not support multiple buildpacks. The buildpack
[heroku-buildpack-multi ](https://github.com/heroku/heroku-buildpack-multi/ ),
used in the backend to parse the `.buildpacks` file, does not provide
the necessary commands `bin/test-compile` and `bin/test` .
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
To use only a single custom buildpack, you should provide the project CI/CD variable
2020-04-22 19:07:51 +05:30
`BUILDPACK_URL` instead.
2023-03-17 16:20:25 +05:30
## Custom Dockerfiles
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
> `DOCKERFILE_PATH` [introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/35662) in GitLab 13.2.
2020-07-28 23:09:34 +05:30
2023-03-17 16:20:25 +05:30
If you have a Dockerfile in the root of your project repository, Auto
DevOps builds a Docker image based on the Dockerfile. This can be
faster than using a buildpack. It can also result in smaller images,
especially if your Dockerfile is based on
[Alpine ](https://hub.docker.com/_/alpine/ ).
2020-04-22 19:07:51 +05:30
2021-04-17 20:07:23 +05:30
If you set the `DOCKERFILE_PATH` CI/CD variable, Auto Build looks for a Dockerfile there
2020-07-28 23:09:34 +05:30
instead.
2023-03-17 16:20:25 +05:30
### Pass arguments to `docker build`
You can pass arguments to `docker build` with the
`AUTO_DEVOPS_BUILD_IMAGE_EXTRA_ARGS` project CI/CD variable.
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
For example, to build a Docker image based on based on the
`ruby:alpine` instead of the default `ruby:latest` :
2020-04-22 19:07:51 +05:30
1. Set `AUTO_DEVOPS_BUILD_IMAGE_EXTRA_ARGS` to `--build-arg=RUBY_VERSION=alpine` .
2023-03-17 16:20:25 +05:30
1. Add the following to a custom Dockerfile:
2020-04-22 19:07:51 +05:30
```dockerfile
ARG RUBY_VERSION=latest
FROM ruby:$RUBY_VERSION
# ... put your stuff here
```
2023-03-17 16:20:25 +05:30
To pass complex values like spaces and newlines, use Base64 encoding.
Complex, unencoded values can cause issues with character escaping.
2020-04-22 19:07:51 +05:30
2021-02-22 17:27:13 +05:30
WARNING:
2023-03-17 16:20:25 +05:30
Do not pass secrets as Docker build arguments. Secrets might persist in your image. For more information, see
[this discussion of best practices with secrets ](https://github.com/moby/moby/issues/13490 ).
2020-04-22 19:07:51 +05:30
2021-12-11 22:18:48 +05:30
## Custom container image
By default, [Auto Deploy ](stages.md#auto-deploy ) deploys a container image built and pushed to the GitLab registry by [Auto Build ](stages.md#auto-build ).
You can override this behavior by defining specific variables:
| Entry | Default | Can be overridden by |
| ----- | ----- | ----- |
| Image Path | `$CI_REGISTRY_IMAGE/$CI_COMMIT_REF_SLUG` for branch pipelines. `$CI_REGISTRY_IMAGE` for tag pipelines. | `$CI_APPLICATION_REPOSITORY` |
| Image Tag | `$CI_COMMIT_SHA` for branch pipelines. `$CI_COMMIT_TAG` for tag pipelines. | `$CI_APPLICATION_TAG` |
2022-01-26 12:08:38 +05:30
These variables also affect Auto Build and Auto Container Scanning. If you don't want to build and push an image to
2023-03-17 16:20:25 +05:30
`$CI_APPLICATION_REPOSITORY:$CI_APPLICATION_TAG` , include only `Jobs/Deploy.gitlab-ci.yml` , or
[disable the `build` jobs ](cicd_variables.md#job-disabling-variables ).
2021-12-11 22:18:48 +05:30
2022-01-26 12:08:38 +05:30
If you use Auto Container Scanning and set a value for `$CI_APPLICATION_REPOSITORY` , then you should
2023-03-17 16:20:25 +05:30
also update `$CS_DEFAULT_BRANCH_IMAGE` . For more information, see
[Setting the default branch image ](../../user/application_security/container_scanning/index.md#setting-the-default-branch-image ).
2022-01-26 12:08:38 +05:30
2021-12-11 22:18:48 +05:30
Here is an example setup in your `.gitlab-ci.yml` :
```yaml
variables:
CI_APPLICATION_REPOSITORY: < your-image-repository >
CI_APPLICATION_TAG: < the-tag >
```
2020-10-24 23:57:45 +05:30
## Extend Auto DevOps with the API
You can extend and manage your Auto DevOps configuration with GitLab APIs:
2023-03-17 16:20:25 +05:30
- [Use API calls to access settings ](../../api/settings.md#list-of-settings-that-can-be-accessed-via-api-calls ),
2020-10-24 23:57:45 +05:30
which include `auto_devops_enabled` , to enable Auto DevOps on projects by default.
2023-03-17 16:20:25 +05:30
- [Create a new project ](../../api/projects.md#create-project ).
- [Edit groups ](../../api/groups.md#update-group ).
- [Edit projects ](../../api/projects.md#edit-project ).
2020-10-24 23:57:45 +05:30
2021-04-17 20:07:23 +05:30
## Forward CI/CD variables to the build environment
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/25514) in GitLab 12.3.
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
To forward CI/CD variables to the build environment, add the names of the variables
you want to forward to the `AUTO_DEVOPS_BUILD_IMAGE_FORWARDED_CI_VARIABLES` CI/CD variable.
Separate multiple variables with commas.
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
For example, to forward the variables `CI_COMMIT_SHA` and `CI_ENVIRONMENT_NAME` :
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
```yaml
variables:
AUTO_DEVOPS_BUILD_IMAGE_FORWARDED_CI_VARIABLES: CI_COMMIT_SHA,CI_ENVIRONMENT_NAME
```
If you use buildpacks, the forwarded variables are available automatically as environment variables.
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
If you use a Dockerfile:
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
1. To activate the experimental Dockerfile syntax, add the following to your Dockerfile:
```dockerfile
# syntax = docker/dockerfile:experimental
```
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
1. To make secrets available in any `RUN $COMMAND` in the `Dockerfile` , mount
the secret file and source it before you run `$COMMAND` :
```dockerfile
RUN --mount=type=secret,id=auto-devops-build-secrets . /run/secrets/auto-devops-build-secrets & & $COMMAND
```
2020-04-22 19:07:51 +05:30
When `AUTO_DEVOPS_BUILD_IMAGE_FORWARDED_CI_VARIABLES` is set, Auto DevOps
2023-01-13 00:05:48 +05:30
enables the experimental [Docker BuildKit ](https://docs.docker.com/build/buildkit/ )
2020-04-22 19:07:51 +05:30
feature to use the `--secret` flag.
2023-03-17 16:20:25 +05:30
## Custom Helm chart
2020-04-22 19:07:51 +05:30
Auto DevOps uses [Helm ](https://helm.sh/ ) to deploy your application to Kubernetes.
2023-03-17 16:20:25 +05:30
You can override the Helm chart used by bundling a chart in your project
2021-04-17 20:07:23 +05:30
repository or by specifying a project CI/CD variable:
2020-04-22 19:07:51 +05:30
- **Bundled chart** - If your project has a `./chart` directory with a `Chart.yaml`
2021-02-22 17:27:13 +05:30
file in it, Auto DevOps detects the chart and uses it instead of the
2023-03-17 16:20:25 +05:30
[default chart ](https://gitlab.com/gitlab-org/cluster-integration/auto-deploy-image/-/tree/master/assets/auto-deploy-app ).
2021-09-30 23:02:18 +05:30
- **Project variable** - Create a [project CI/CD variable ](../../ci/variables/index.md )
2023-03-17 16:20:25 +05:30
`AUTO_DEVOPS_CHART` with the URL of a custom chart. You can also create two project
variables:
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
- `AUTO_DEVOPS_CHART_REPOSITORY` - The URL of a custom chart repository.
- `AUTO_DEVOPS_CHART` - The path to the chart.
### Customize Helm chart values
2020-04-22 19:07:51 +05:30
2021-02-22 17:27:13 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/30628) in GitLab 12.6, `.gitlab/auto-deploy-values.yaml` is used by default for Helm upgrades.
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
To override the default values in the `values.yaml` file in the
[default Helm chart ](https://gitlab.com/gitlab-org/cluster-integration/auto-deploy-image/-/tree/master/assets/auto-deploy-app ), either:
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
- Add a file named `.gitlab/auto-deploy-values.yaml` to your repository. This file is automatically used.
- Add a file with a different name or path to the repository. Set the
`HELM_UPGRADE_VALUES_FILE` [CI/CD variable ](cicd_variables.md ) with the path and name of the file.
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
Some values cannot be overridden with the options above, but [this issue ](https://gitlab.com/gitlab-org/cluster-integration/auto-deploy-image/-/issues/31 ) proposes to change this behavior.
To override settings like `replicaCount` , use the `REPLICAS` [build and deployment ](cicd_variables.md#build-and-deployment-variables ) CI/CD variable.
2022-04-04 11:22:00 +05:30
2023-03-17 16:20:25 +05:30
### Customize `helm upgrade`
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
The [auto-deploy-image ](https://gitlab.com/gitlab-org/cluster-integration/auto-deploy-image ) uses the `helm upgrade` command.
To customize this command, pass it options with the `HELM_UPGRADE_EXTRA_ARGS` CI/CD variable.
2020-11-24 15:15:51 +05:30
2023-03-17 16:20:25 +05:30
For example, to disable pre- and post-upgrade hooks when `helm upgrade` runs:
2020-11-24 15:15:51 +05:30
2023-03-17 16:20:25 +05:30
```yaml
variables:
HELM_UPGRADE_EXTRA_ARGS: --no-hooks
```
2020-11-24 15:15:51 +05:30
2023-03-17 16:20:25 +05:30
For a full list of options, see [the official `helm upgrade` documentation ](https://helm.sh/docs/helm/helm_upgrade/ ).
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
### Limit a Helm chart to one environment
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
To limit a custom chart to one environment, add the environment scope to your CI/CD variables.
For more information, see [Limit the environment scope of CI/CD variables ](../../ci/environments/index.md#limit-the-environment-scope-of-a-cicd-variable ).
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
## Customize `.gitlab-ci.yml`
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
Auto DevOps is highly customizable because the [Auto DevOps template ](https://gitlab.com/gitlab-org/gitlab/-/blob/master/lib/gitlab/ci/templates/Auto-DevOps.gitlab-ci.yml )
is an implementation of a [`.gitlab-ci.yml` ](../../ci/yaml/index.md ) file.
The template uses only features available to any implementation of `.gitlab-ci.yml` .
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
To add custom behaviors to the CI/CD pipeline used by Auto DevOps:
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
1. To the root of your repository, add a `.gitlab-ci.yml` file with the following contents:
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
```yaml
include:
- template: Auto-DevOps.gitlab-ci.yml
```
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
1. Add your changes to the `.gitlab-ci.yml` file. Your changes are merged with the Auto DevOps template. For more information about
how `include` merges your changes, see [the `include` documentation ](../../ci/yaml/index.md#include ).
2021-10-27 15:23:28 +05:30
2023-03-17 16:20:25 +05:30
To remove behaviors from the Auto DevOps pipeline:
2021-10-27 15:23:28 +05:30
2023-03-17 16:20:25 +05:30
1. Copy the [Auto DevOps template ](https://gitlab.com/gitlab-org/gitlab/-/blob/master/lib/gitlab/ci/templates/Auto-DevOps.gitlab-ci.yml )
into your project.
1. Edit your copy of the template as needed.
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
### Use individual components of Auto DevOps
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
If you only require a subset of the features offered by Auto DevOps,
you can include individual Auto DevOps jobs in your own
`.gitlab-ci.yml` . Be sure to also define the stage required by each
job in your `.gitlab-ci.yml` file.
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
For example, to use [Auto Build ](stages.md#auto-build ), you can add the following to
2020-04-22 19:07:51 +05:30
your `.gitlab-ci.yml` :
```yaml
stages:
- build
include:
- template: Jobs/Build.gitlab-ci.yml
```
2023-03-17 16:20:25 +05:30
For a list of available jobs, see the [Auto DevOps template ](https://gitlab.com/gitlab-org/gitlab/-/blob/master/lib/gitlab/ci/templates/Auto-DevOps.gitlab-ci.yml ).
2020-04-22 19:07:51 +05:30
2021-02-22 17:27:13 +05:30
WARNING:
2023-03-17 16:20:25 +05:30
From [GitLab 13.0 ](https://gitlab.com/gitlab-org/gitlab/-/issues/213336 ),
Auto DevOps templates that use the [`only` ](../../ci/yaml/index.md#only--except ) or
2021-09-30 23:02:18 +05:30
[`except` ](../../ci/yaml/index.md#only--except ) syntax have switched
2023-03-17 16:20:25 +05:30
to the [`rules` ](../../ci/yaml/index.md#rules ) syntax.
If your `.gitlab-ci.yml` extends these Auto DevOps templates and overrides `only` or
`except` , migrate your templates to the
[`rules` ](../../ci/yaml/index.md#rules ) syntax.
If you cannot migrate, you can pin your templates to
2020-05-24 23:13:21 +05:30
the [GitLab 12.10 based templates ](https://gitlab.com/gitlab-org/auto-devops-v12-10 ).
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
## Use multiple Kubernetes clusters
See [Multiple Kubernetes clusters for Auto DevOps ](multiple_clusters_auto_devops.md ).
## Customizing the Kubernetes namespace
In GitLab 14.5 and earlier, you could use `environment:kubernetes:namespace`
to specify a namespace for the environment.
However, this feature was [deprecated ](https://gitlab.com/groups/gitlab-org/configure/-/epics/8 ),
along with certificate-based integration.
You should now use the `KUBE_NAMESPACE` environment variable and
[limit its environment scope ](../../ci/environments/index.md#limit-the-environment-scope-of-a-cicd-variable ).
2021-09-04 01:27:46 +05:30
## Use images hosted in a local Docker registry
You can configure many Auto DevOps jobs to run in an [offline environment ](../../user/application_security/offline_deployments/index.md ):
1. Copy the required Auto DevOps Docker images from Docker Hub and `registry.gitlab.com` to their local GitLab container registry.
2023-03-17 16:20:25 +05:30
1. After the images are hosted and available in a local registry, edit `.gitlab-ci.yml` to point to the locally hosted images. For example:
2021-09-04 01:27:46 +05:30
```yaml
include:
- template: Auto-DevOps.gitlab-ci.yml
variables:
REGISTRY_URL: "registry.gitlab.example"
build:
image: "$REGISTRY_URL/docker/auto-build-image:v0.6.0"
services:
2022-08-13 15:12:31 +05:30
- name: "$REGISTRY_URL/greg/docker/docker:20.10.16-dind"
2021-09-04 01:27:46 +05:30
command: ['--tls=false', '--host=tcp://0.0.0.0:2375']
```
2020-04-22 19:07:51 +05:30
## PostgreSQL database support
2023-03-17 16:20:25 +05:30
WARNING:
Provisioning a PostgreSQL database by default was [deprecated ](https://gitlab.com/gitlab-org/gitlab/-/issues/387766 )
in GitLab 15.8 and will no longer be the default from 16.0. To enable database provisioning, set
the associated [CI/CD variable ](cicd_variables.md#database-variables ).
To support applications that require a database,
[PostgreSQL ](https://www.postgresql.org/ ) is provisioned by default.
The credentials to access the database are preconfigured.
To customize the credentials, set the associated
[CI/CD variables ](cicd_variables.md ). You can also
define a custom `DATABASE_URL` :
2020-04-22 19:07:51 +05:30
```yaml
postgres://user:password@postgres-host:postgres-port/postgres-database
```
2023-03-04 22:38:38 +05:30
### Upgrading PostgreSQL
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
GitLab uses chart version 8.2.1 to provision PostgreSQL by default.
You can set the version from 0.7.1 to 8.2.1.
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
If you use an older chart version, you should [migrate your database ](upgrading_postgresql.md )
2020-04-22 19:07:51 +05:30
to the newer PostgreSQL.
2023-03-17 16:20:25 +05:30
The CI/CD variable `AUTO_DEVOPS_POSTGRES_CHANNEL` that controls default provisioned
PostgreSQL changed to `2` in [GitLab 13.0 ](https://gitlab.com/gitlab-org/gitlab/-/issues/210499 ).
To use the old PostgreSQL, set the `AUTO_DEVOPS_POSTGRES_CHANNEL` variable to
`1` .
2021-09-30 23:02:18 +05:30
### Customize values for PostgreSQL Helm Chart
2023-03-17 16:20:25 +05:30
> [Introduced](https://gitlab.com/gitlab-org/cluster-integration/auto-deploy-image/-/issues/113) in GitLab 13.8 with auto-deploy-image v2.
2021-09-30 23:02:18 +05:30
To set custom values, do one of the following:
- Add a file named `.gitlab/auto-deploy-postgres-values.yaml` to your repository. If found, this
file is used automatically. This file is used by default for PostgreSQL Helm upgrades.
- Add a file with a different name or path to the repository, and set the
2023-03-04 22:38:38 +05:30
`POSTGRES_HELM_UPGRADE_VALUES_FILE` [environment variable ](cicd_variables.md#database-variables ) with the path
2021-09-30 23:02:18 +05:30
and name.
2023-03-04 22:38:38 +05:30
- Set the `POSTGRES_HELM_UPGRADE_EXTRA_ARGS` [environment variable ](cicd_variables.md#database-variables ).
2021-09-30 23:02:18 +05:30
2023-03-17 16:20:25 +05:30
### Use external PostgreSQL database providers
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
Auto DevOps provides out-of-the-box support for a PostgreSQL container
for production environments. However, you might want to use an
external managed provider like AWS Relational Database Service.
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
To use an external managed provider:
2020-04-22 19:07:51 +05:30
2023-03-17 16:20:25 +05:30
1. Disable the built-in PostgreSQL installation for the required environments with
environment-scoped [CI/CD variables ](../../ci/environments/index.md#limit-the-environment-scope-of-a-cicd-variable ).
Because the built-in PostgreSQL setup for Review Apps and staging is sufficient, you might only need to
disable the installation for `production` .
2020-04-22 19:07:51 +05:30
![Auto Metrics ](img/disable_postgres.png )
2023-03-17 16:20:25 +05:30
1. Define the `DATABASE_URL` variable as an environment-scoped variable
2020-04-22 19:07:51 +05:30
available to your application. This should be a URL in the following format:
```yaml
postgres://user:password@postgres-host:postgres-port/postgres-database
```
2023-03-17 16:20:25 +05:30
1. Ensure your Kubernetes cluster has network access to where PostgreSQL is hosted.