2019-10-12 21:52:04 +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
2019-10-12 21:52:04 +05:30
---
2021-04-29 21:17:54 +05:30
# Releases **(FREE)**
2019-02-15 15:39:39 +05:30
2022-01-26 12:08:38 +05:30
In GitLab, a release enables you to create a snapshot of your project for your users, including
installation packages and release notes. You can create a GitLab release on any branch. Creating a
release also creates a [Git tag ](https://git-scm.com/book/en/v2/Git-Basics-Tagging ) to mark the
release point in the source code.
2020-07-28 23:09:34 +05:30
2022-01-26 12:08:38 +05:30
WARNING:
Deleting a Git tag associated with a release also deletes the release.
A release can include:
2021-09-30 23:02:18 +05:30
- A snapshot of the source code of your repository.
- [Generic packages ](../../packages/generic_packages/index.md ) created from job artifacts.
- Other metadata associated with a released version of your code.
2022-01-26 12:08:38 +05:30
- Release notes.
2019-02-15 15:39:39 +05:30
2022-01-26 12:08:38 +05:30
When you [create a release ](#create-a-release ):
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
- GitLab automatically archives source code and associates it with the release.
- GitLab automatically creates a JSON file that lists everything in the release,
2023-07-09 08:55:56 +05:30
so you can compare and audit releases. This file is called [release evidence ](release_evidence.md ).
2019-02-15 15:39:39 +05:30
2022-01-26 12:08:38 +05:30
When you create a release, or after, you can:
- Add release notes.
- Add a message for the Git tag associated with the release.
- [Associate milestones with it ](#associate-milestones-with-a-release ).
2022-08-27 11:52:29 +05:30
- Attach [release assets ](release_fields.md#release-assets ), like runbooks or packages.
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
## View releases
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
To view a list of releases:
2020-04-08 14:13:33 +05:30
2021-09-04 01:27:46 +05:30
- On the left sidebar, select **Deployments > Releases** , or
2020-07-28 23:09:34 +05:30
2022-05-07 20:08:51 +05:30
- On the project's overview page, if at least one release exists, select the number of releases.
2020-07-28 23:09:34 +05:30
![Number of Releases ](img/releases_count_v13_2.png "Incremental counter of Releases" )
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
- On public projects, this number is visible to all users.
2023-07-09 08:55:56 +05:30
- On private projects, this number is visible to users with at least the Reporter
[role ](../../permissions.md#project-members-permissions ).
2019-02-15 15:39:39 +05:30
2022-01-26 12:08:38 +05:30
### Sort releases
2021-01-29 00:20:46 +05:30
2022-05-07 20:08:51 +05:30
To sort releases by **Released date** or **Created date** , select from the sort order dropdown list. To
2022-01-26 12:08:38 +05:30
switch between ascending or descending order, select **Sort order** .
2021-01-29 00:20:46 +05:30
2022-05-07 20:08:51 +05:30
![Sort releases dropdown list options ](img/releases_sort_v13_6.png )
2021-01-29 00:20:46 +05:30
2020-07-28 23:09:34 +05:30
## Create a release
2022-01-26 12:08:38 +05:30
You can create a release:
2019-02-15 15:39:39 +05:30
2022-07-23 23:45:48 +05:30
- [Using a job in your CI/CD pipeline ](#creating-a-release-by-using-a-cicd-job ).
2022-01-26 12:08:38 +05:30
- [In the Releases page ](#create-a-release-in-the-releases-page ).
- Using the [Releases API ](../../../api/releases/index.md#create-a-release ).
2023-07-09 08:55:56 +05:30
You should create a release as one of the last steps in your CI/CD pipeline.
2022-01-26 12:08:38 +05:30
2022-10-11 01:57:18 +05:30
### Create a release in the Releases page
2022-01-26 12:08:38 +05:30
Prerequisites:
- You must have at least the Developer role for a project. For more information, read
[Release permissions ](#release-permissions ).
To create a release in the Releases page:
2019-02-15 15:39:39 +05:30
2022-10-11 01:57:18 +05:30
1. On the top bar, select **Main menu > Projects** and find your project.
2021-09-04 01:27:46 +05:30
1. On the left sidebar, select **Deployments > Releases** and select **New release** .
2022-11-25 23:54:43 +05:30
1. From the [**Tag name** ](release_fields.md#tag-name ) dropdown list, either:
2022-01-26 12:08:38 +05:30
- Select an existing Git tag. Selecting an existing tag that is already associated with a release
results in a validation error.
- Enter a new Git tag name.
2023-06-20 00:43:36 +05:30
1. From the **Create tag** popover, select a branch or commit SHA to use when
2022-11-25 23:54:43 +05:30
creating the new tag.
1. Optional. In the **Set tag message** text box, enter a message to create an
[annotated tag ](https://git-scm.com/book/en/v2/Git-Basics-Tagging#_annotated_tags ).
2023-06-20 00:43:36 +05:30
1. Select **Save** .
2022-01-26 12:08:38 +05:30
1. Optional. Enter additional information about the release, including:
2022-08-27 11:52:29 +05:30
- [Title ](release_fields.md#title ).
2022-01-26 12:08:38 +05:30
- [Milestones ](#associate-milestones-with-a-release ).
2022-08-27 11:52:29 +05:30
- [Release notes ](release_fields.md#release-notes-description ).
2023-05-27 22:25:52 +05:30
- Whether or not to include the [Tag message ](../repository/tags/index.md ).
2022-08-27 11:52:29 +05:30
- [Asset links ](release_fields.md#links ).
2022-01-26 12:08:38 +05:30
1. Select **Create release** .
2022-07-23 23:45:48 +05:30
### Creating a release by using a CI/CD job
2021-02-22 17:27:13 +05:30
2022-07-23 23:45:48 +05:30
You can create a release directly as part of the GitLab CI/CD pipeline by using the
[`release` keyword ](../../../ci/yaml/index.md#release ) in the job definition.
2021-02-22 17:27:13 +05:30
2022-01-26 12:08:38 +05:30
The release is created only if the job processes without error. If the API returns an error during
release creation, the release job fails.
2021-02-22 17:27:13 +05:30
2022-10-11 01:57:18 +05:30
Methods for creating a release using a CI/CD job include:
- [Create a release when a Git tag is created ](release_cicd_examples.md#create-a-release-when-a-git-tag-is-created ).
- [Create a release when a commit is merged to the default branch ](release_cicd_examples.md#create-a-release-when-a-commit-is-merged-to-the-default-branch ).
- [Create release metadata in a custom script ](release_cicd_examples.md#create-release-metadata-in-a-custom-script ).
2022-07-23 23:45:48 +05:30
2021-12-11 22:18:48 +05:30
### Use a custom SSL CA certificate authority
You can use the `ADDITIONAL_CA_CERT_BUNDLE` CI/CD variable to configure a custom SSL CA certificate authority,
which is used to verify the peer when the `release-cli` creates a release through the API using HTTPS with custom certificates.
The `ADDITIONAL_CA_CERT_BUNDLE` value should contain the
2022-11-25 23:54:43 +05:30
[text representation of the X.509 PEM public-key certificate ](https://www.rfc-editor.org/rfc/rfc7468#section-5.1 )
2021-12-11 22:18:48 +05:30
or the `path/to/file` containing the certificate authority.
For example, to configure this value in the `.gitlab-ci.yml` file, use the following:
```yaml
release:
variables:
ADDITIONAL_CA_CERT_BUNDLE: |
-----BEGIN CERTIFICATE-----
MIIGqTCCBJGgAwIBAgIQI7AVxxVwg2kch4d56XNdDjANBgkqhkiG9w0BAQsFADCB
...
jWgmPqF3vUbZE0EyScetPJquRFRKIesyJuBFMAs=
-----END CERTIFICATE-----
script:
- echo "Create release"
release:
name: 'My awesome release'
tag_name: '$CI_COMMIT_TAG'
```
The `ADDITIONAL_CA_CERT_BUNDLE` value can also be configured as a
2023-03-17 16:20:25 +05:30
[custom variable in the UI ](../../../ci/variables/index.md#for-a-project ),
2021-12-11 22:18:48 +05:30
either as a `file` , which requires the path to the certificate, or as a variable,
which requires the text representation of the certificate.
### Create multiple releases in a single pipeline
A pipeline can have multiple `release` jobs, for example:
```yaml
ios-release:
script:
2022-01-26 12:08:38 +05:30
- echo "iOS release job"
2021-12-11 22:18:48 +05:30
release:
tag_name: v1.0.0-ios
description: 'iOS release v1.0.0'
android-release:
script:
2022-01-26 12:08:38 +05:30
- echo "Android release job"
2021-12-11 22:18:48 +05:30
release:
tag_name: v1.0.0-android
description: 'Android release v1.0.0'
```
### Release assets as Generic packages
You can use [Generic packages ](../../packages/generic_packages/index.md ) to host your release assets.
For a complete example, see the [Release assets as Generic packages ](https://gitlab.com/gitlab-org/release-cli/-/tree/master/docs/examples/release-assets-as-generic-package/ )
project.
## Upcoming releases
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/issues/38105) in GitLab 12.1.
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
You can create a release ahead of time by using the [Releases API ](../../../api/releases/index.md#upcoming-releases ).
When you set a future `released_at` date, an **Upcoming Release** badge is displayed next to the
release tag. When the `released_at` date and time has passed, the badge is automatically removed.
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
![An upcoming release ](img/upcoming_release_v12_7.png )
2020-06-23 00:09:42 +05:30
2022-08-27 11:52:29 +05:30
## Historical releases
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/199429) in GitLab 15.2.
2020-04-08 14:13:33 +05:30
2022-08-27 11:52:29 +05:30
You can create a release in the past using either the
[Releases API ](../../../api/releases/index.md#historical-releases ) or the UI. When you set
a past `released_at` date, an **Historical release** badge is displayed next to
2023-07-09 08:55:56 +05:30
the release tag. Due to being released in the past, [release evidence ](release_evidence.md )
2022-08-27 11:52:29 +05:30
is not available.
## Edit a release
2020-04-08 14:13:33 +05:30
2023-03-04 22:38:38 +05:30
To edit the details of a release after it's created, you can use the
[Update a release API ](../../../api/releases/index.md#update-a-release ) or the UI.
2020-04-08 14:13:33 +05:30
2023-03-04 22:38:38 +05:30
Prerequisites:
- You must have at least the Developer role.
In the UI:
2020-04-08 14:13:33 +05:30
2021-09-04 01:27:46 +05:30
1. On the left sidebar, select **Deployments > Releases** .
2023-04-23 21:23:45 +05:30
1. In the upper-right corner of the release you want to modify, select **Edit this release** (the pencil icon).
2020-07-28 23:09:34 +05:30
1. On the **Edit Release** page, change the release's details.
2022-05-07 20:08:51 +05:30
1. Select **Save changes** .
2020-04-08 14:13:33 +05:30
2022-08-13 15:12:31 +05:30
## Delete a release
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/213862) in GitLab 15.2
When you delete a release, its assets are also deleted. However, the associated
Git tag is not deleted.
Prerequisites:
- You must have at least the Developer role. Read more about [Release permissions ](#release-permissions ).
2023-03-04 22:38:38 +05:30
To delete a release, use either the
[Delete a release API ](../../../api/releases/index.md#delete-a-release ) or the UI.
In the UI:
2022-08-13 15:12:31 +05:30
2022-10-11 01:57:18 +05:30
1. On the top bar, select **Main menu > Projects** and find your project.
2022-08-13 15:12:31 +05:30
1. On the left sidebar, select **Deployments > Releases** .
2023-04-23 21:23:45 +05:30
1. In the upper-right corner of the release you want to delete, select **Edit this release**
2023-03-04 22:38:38 +05:30
(**{pencil}**).
2022-08-13 15:12:31 +05:30
1. On the **Edit Release** page, select **Delete** .
1. Select **Delete release** .
2020-07-28 23:09:34 +05:30
## Associate milestones with a release
2019-12-26 22:10:19 +05:30
2020-06-23 00:09:42 +05:30
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/29020) in GitLab 12.5.
2020-05-24 23:13:21 +05:30
> - [Updated](https://gitlab.com/gitlab-org/gitlab/-/issues/39467) to edit milestones in the UI in GitLab 13.0.
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
You can associate a release with one or more [project milestones ](../milestones/index.md#project-milestones-and-group-milestones ).
2021-01-29 00:20:46 +05:30
[GitLab Premium ](https://about.gitlab.com/pricing/ ) customers can specify [group milestones ](../milestones/index.md#project-milestones-and-group-milestones ) to associate with a release.
2020-07-28 23:09:34 +05:30
You can do this in the user interface, or by including a `milestones` array in your request to
the [Releases API ](../../../api/releases/index.md#create-a-release ).
In the user interface, to associate milestones to a release:
2020-05-24 23:13:21 +05:30
2021-09-04 01:27:46 +05:30
1. On the left sidebar, select **Deployments > Releases** .
2023-04-23 21:23:45 +05:30
1. In the upper-right corner of the release you want to modify, select **Edit this release** (the pencil icon).
2020-07-28 23:09:34 +05:30
1. From the **Milestones** list, select each milestone you want to associate. You can select multiple milestones.
2022-05-07 20:08:51 +05:30
1. Select **Save changes** .
2019-12-26 22:10:19 +05:30
2021-09-04 01:27:46 +05:30
On the **Deployments > Releases** page, the **Milestone** is listed in the top
2020-07-28 23:09:34 +05:30
section, along with statistics about the issues in the milestones.
2019-12-26 22:10:19 +05:30
2020-04-08 14:13:33 +05:30
![A Release with one associated milestone ](img/release_with_milestone_v12_9.png )
2019-12-26 22:10:19 +05:30
2022-05-07 20:08:51 +05:30
Releases are also visible on the **Issues > Milestones** page, and when you select a milestone
2020-07-28 23:09:34 +05:30
on this page.
2023-07-09 08:55:56 +05:30
Here is an example of milestones with no releases, one release, and two releases.
2019-12-26 22:10:19 +05:30
![Milestones with and without Release associations ](img/milestone_list_with_releases_v12_5.png )
2022-01-26 12:08:38 +05:30
NOTE:
2023-07-09 08:55:56 +05:30
A subgroup's project releases cannot be associated with a parent group's milestone. To learn
2022-01-26 12:08:38 +05:30
more, read issue #328054 ,
[Releases cannot be associated with a supergroup milestone ](https://gitlab.com/gitlab-org/gitlab/-/issues/328054 ).
2020-07-28 23:09:34 +05:30
## Get notified when a release is created
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/26001) in GitLab 12.4.
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
You can be notified by email when a new release is created for your project.
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
To subscribe to notifications for releases:
2019-02-15 15:39:39 +05:30
2021-09-04 01:27:46 +05:30
1. On the left sidebar, select **Project information** .
2022-05-07 20:08:51 +05:30
1. Select **Notification setting** (the bell icon).
1. In the list, select **Custom** .
2021-10-27 15:23:28 +05:30
1. Select the **New release** checkbox.
2020-07-28 23:09:34 +05:30
1. Close the dialog box to save.
2019-10-12 21:52:04 +05:30
2020-07-28 23:09:34 +05:30
## Prevent unintentional releases by setting a deploy freeze
2020-03-13 15:44:24 +05:30
2021-11-11 11:23:49 +05:30
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/29382) in GitLab 13.0.
> - The ability to delete freeze periods through the UI was [introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/212451) in GitLab 14.3.
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
Prevent unintended production releases during a period of time you specify by
setting a [*deploy freeze* period ](../../../ci/environments/deployment_safety.md ).
Deploy freezes help reduce uncertainty and risk when automating deployments.
2020-03-13 15:44:24 +05:30
2020-10-24 23:57:45 +05:30
A maintainer can set a deploy freeze window in the user interface or by using the [Freeze Periods API ](../../../api/freeze_periods.md ) to set a `freeze_start` and a `freeze_end` , which
2020-07-28 23:09:34 +05:30
are defined as [crontab ](https://crontab.guru/ ) entries.
2020-03-13 15:44:24 +05:30
2023-07-09 08:55:56 +05:30
If the job that's executing is in a freeze period, GitLab CI/CD creates an environment
2020-07-28 23:09:34 +05:30
variable named `$CI_DEPLOY_FREEZE` .
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
To prevent the deployment job from executing, create a `rules` entry in your
2021-11-11 11:23:49 +05:30
`.gitlab-ci.yml` , for example:
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
```yaml
deploy_to_production:
stage: deploy
script: deploy_to_prod.sh
rules:
- if: $CI_DEPLOY_FREEZE == null
2022-10-11 01:57:18 +05:30
environment: production
2020-07-28 23:09:34 +05:30
```
2020-03-13 15:44:24 +05:30
2020-10-24 23:57:45 +05:30
To set a deploy freeze window in the UI, complete these steps:
2022-04-04 11:22:00 +05:30
1. Sign in to GitLab as a user with the Maintainer role.
2021-09-04 01:27:46 +05:30
1. On the left sidebar, select **Project information** .
2022-05-07 20:08:51 +05:30
1. In the left navigation menu, go to **Settings > CI/CD** .
2020-10-24 23:57:45 +05:30
1. Scroll to **Deploy freezes** .
2022-05-07 20:08:51 +05:30
1. Select **Expand** to see the deploy freeze table.
1. Select **Add deploy freeze** to open the deploy freeze modal.
2021-11-18 22:05:49 +05:30
1. Enter the start time, end time, and time zone of the desired deploy freeze period.
2022-05-07 20:08:51 +05:30
1. Select **Add deploy freeze** in the modal.
2021-11-11 11:23:49 +05:30
1. After the deploy freeze is saved, you can edit it by selecting the edit button (**{pencil}**) and remove it by selecting the delete button (**{remove}**).
![Deploy freeze modal for setting a deploy freeze period ](img/deploy_freeze_v14_3.png )
2020-10-24 23:57:45 +05:30
2020-07-28 23:09:34 +05:30
If a project contains multiple freeze periods, all periods apply. If they overlap, the freeze covers the
complete overlapping period.
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
For more information, see [Deployment safety ](../../../ci/environments/deployment_safety.md ).
2020-03-13 15:44:24 +05:30
2021-09-30 23:02:18 +05:30
## Release permissions
2023-03-04 22:38:38 +05:30
> Fixes to the permission model for create, update and delete actions [were introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/327505) in GitLab 14.1.
2021-09-30 23:02:18 +05:30
### View a release and download assets
2023-03-04 22:38:38 +05:30
> Changes to the Guest role [were introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/335209) in GitLab 14.5.
2021-12-11 22:18:48 +05:30
2022-04-04 11:22:00 +05:30
- Users with at least the Reporter role
2021-12-11 22:18:48 +05:30
have read and download access to the project releases.
2022-04-04 11:22:00 +05:30
- Users with the Guest role
2021-09-30 23:02:18 +05:30
have read and download access to the project releases.
2021-12-11 22:18:48 +05:30
This includes associated Git-tag-names, release description, author information of the releases.
2023-07-09 08:55:56 +05:30
However, other repository-related information, such as [source code ](release_fields.md#source-code ) and
[release evidence ](release_evidence.md ) are redacted.
2021-09-30 23:02:18 +05:30
2023-01-13 00:05:48 +05:30
### Publish releases without giving access to source code
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/216485) in GitLab 15.6.
Releases can be made accessible to non-project members while keeping repository-related information such as
2023-07-09 08:55:56 +05:30
[source code ](release_fields.md#source-code ) and [release evidence ](release_evidence.md ) private. Use this for
2023-01-13 00:05:48 +05:30
projects that use releases as a way to give access to new versions of software but do not want the source code to
be public.
To make releases available publicly, set the following [project settings ](../settings/index.md#project-feature-settings ):
- Repository is enabled and set to **Only Project Members**
- Releases is enabled and set to **Everyone With Access**
2021-09-30 23:02:18 +05:30
### Create, update, and delete a release and its assets
2022-04-04 11:22:00 +05:30
- Users with at least the Developer role
2021-09-30 23:02:18 +05:30
have write access to the project releases and assets.
- If a release is associated with a [protected tag ](../protected_tags.md ),
the user must be [allowed to create the protected tag ](../protected_tags.md#configuring-protected-tags ) too.
As an example of release permission control, you can allow only
2022-04-04 11:22:00 +05:30
users with at least the Maintainer role
2021-09-30 23:02:18 +05:30
to create, update, and delete releases by protecting the tag with a wildcard (`*`),
and set **Maintainer** in the **Allowed to create** column.
2021-04-17 20:07:23 +05:30
## Release Metrics **(ULTIMATE)**
2021-03-11 19:13:27 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/259703) in GitLab Premium 13.9.
Group-level release metrics are available by navigating to **Group > Analytics > CI/CD** .
These metrics include:
- Total number of releases in the group
- Percentage of projects in the group that have at least one release
2021-10-27 15:23:28 +05:30
## Working example project
The Guided Exploration project [Utterly Automated Software and Artifact Versioning with GitVersion ](https://gitlab.com/guided-explorations/devops-patterns/utterly-automated-versioning ) demonstrates:
- Using GitLab releases.
- Using the GitLab `release-cli` .
- Creating a generic package.
- Linking the package to the release.
- Using a tool called [GitVersion ](https://gitversion.net/ ) to automatically determine and increment versions for complex repositories.
You can copy the example project to your own group or instance for testing. More details on what other GitLab CI patterns are demonstrated are available at the project page.
2021-09-30 23:02:18 +05:30
## Troubleshooting
### Getting `403 Forbidden` or `Something went wrong while creating a new release` errors when creating, updating or deleting releases and their assets
2019-10-12 21:52:04 +05:30
2022-01-26 12:08:38 +05:30
If the release is associated with a [protected tag ](../protected_tags.md ),
2021-09-30 23:02:18 +05:30
the UI/API request might result in an authorization failure.
Make sure that the user or a service/bot account is allowed to
[create the protected tag ](../protected_tags.md#configuring-protected-tags ) too.
2019-10-12 21:52:04 +05:30
2021-09-30 23:02:18 +05:30
See [the release permissions ](#release-permissions ) for more information.
2022-03-02 08:16:31 +05:30
### Note about storage
2023-07-09 08:55:56 +05:30
This feature is built on top of Git tags, so virtually no extra data is needed besides to create the release itself. Additional assets and the release evidence that is automatically generated consume storage.