2019-05-27 15:53:21 -04:00
|
|
|
---
|
2019-06-07 04:00:41 -04:00
|
|
|
type: howto
|
2019-05-27 15:53:21 -04:00
|
|
|
---
|
|
|
|
|
2017-11-01 11:56:40 -04:00
|
|
|
# How to enable or disable GitLab CI/CD
|
2016-01-06 14:05:22 -05:00
|
|
|
|
2019-06-07 04:00:41 -04:00
|
|
|
To effectively use GitLab CI/CD, you need:
|
|
|
|
|
|
|
|
- A valid [`.gitlab-ci.yml`](yaml/README.md) file present at the root directory
|
|
|
|
of your project.
|
|
|
|
- A [runner](runners/README.md) properly set up.
|
|
|
|
|
|
|
|
You can read our [quick start guide](quick_start/README.md) to get you started.
|
2016-01-06 14:05:22 -05:00
|
|
|
|
2017-10-03 09:11:49 -04:00
|
|
|
If you are using an external CI/CD server like Jenkins or Drone CI, it is advised
|
|
|
|
to disable GitLab CI/CD in order to not have any conflicts with the commits status
|
2016-01-06 14:05:22 -05:00
|
|
|
API.
|
|
|
|
|
2017-10-03 09:11:49 -04:00
|
|
|
GitLab CI/CD is exposed via the `/pipelines` and `/jobs` pages of a project.
|
|
|
|
Disabling GitLab CI/CD in a project does not delete any previous jobs.
|
|
|
|
In fact, the `/pipelines` and `/jobs` pages can still be accessed, although
|
2017-02-03 13:24:17 -05:00
|
|
|
it's hidden from the left sidebar menu.
|
2016-01-06 14:05:22 -05:00
|
|
|
|
2019-06-07 04:00:41 -04:00
|
|
|
GitLab CI/CD is enabled by default on new installations and can be disabled
|
|
|
|
either:
|
|
|
|
|
|
|
|
- Individually under each project's settings.
|
|
|
|
- Site-wide by modifying the settings in `gitlab.yml` and `gitlab.rb` for source
|
|
|
|
and Omnibus installations respectively.
|
2016-01-06 14:05:22 -05:00
|
|
|
|
2019-10-01 20:06:26 -04:00
|
|
|
NOTE: **Note:**
|
|
|
|
This only applies to pipelines run as part of GitLab CI/CD. This will not enable or disable
|
|
|
|
pipelines that are run from an [external integration](../user/project/integrations/project_services.md#services).
|
|
|
|
|
2017-11-01 11:56:40 -04:00
|
|
|
## Per-project user setting
|
2016-01-06 14:05:22 -05:00
|
|
|
|
2019-12-08 22:07:57 -05:00
|
|
|
To enable or disable GitLab CI/CD Pipelines in your project:
|
2019-10-01 20:06:26 -04:00
|
|
|
|
2019-12-08 22:07:57 -05:00
|
|
|
1. Navigate to **Settings > General > Visibility, project features, permissions**.
|
|
|
|
1. Expand the **Repository** section
|
2020-01-03 22:07:35 -05:00
|
|
|
1. Enable or disable the **Pipelines** toggle as required.
|
2019-12-08 22:07:57 -05:00
|
|
|
|
|
|
|
**Project visibility** will also affect pipeline visibility. If set to:
|
|
|
|
|
|
|
|
- **Private**: Only project members can access pipelines.
|
|
|
|
- **Internal** or **Public**: Pipelines can be set to either **Only Project Members**
|
2020-01-16 10:08:41 -05:00
|
|
|
or **Everyone With Access** via the dropdown box.
|
2019-10-01 20:06:26 -04:00
|
|
|
|
|
|
|
Press **Save changes** for the settings to take effect.
|
2016-01-06 14:05:22 -05:00
|
|
|
|
2017-11-01 11:56:40 -04:00
|
|
|
## Site-wide admin setting
|
2016-01-06 14:05:22 -05:00
|
|
|
|
2017-10-03 09:11:49 -04:00
|
|
|
You can disable GitLab CI/CD site-wide, by modifying the settings in `gitlab.yml`
|
2019-10-01 20:06:26 -04:00
|
|
|
for source installations, and `gitlab.rb` for Omnibus installations.
|
2016-01-06 14:05:22 -05:00
|
|
|
|
2016-01-07 04:10:46 -05:00
|
|
|
Two things to note:
|
2016-01-06 14:05:22 -05:00
|
|
|
|
2019-06-07 04:00:41 -04:00
|
|
|
- Disabling GitLab CI/CD, will affect only newly-created projects. Projects that
|
|
|
|
had it enabled prior to this modification, will work as before.
|
|
|
|
- Even if you disable GitLab CI/CD, users will still be able to enable it in the
|
|
|
|
project's settings.
|
2016-01-06 14:05:22 -05:00
|
|
|
|
|
|
|
For installations from source, open `gitlab.yml` with your editor and set
|
|
|
|
`builds` to `false`:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
## Default project features settings
|
|
|
|
default_projects_features:
|
|
|
|
issues: true
|
|
|
|
merge_requests: true
|
|
|
|
wiki: true
|
|
|
|
snippets: false
|
|
|
|
builds: false
|
|
|
|
```
|
|
|
|
|
2019-06-07 04:00:41 -04:00
|
|
|
Save the file and restart GitLab:
|
|
|
|
|
2020-01-30 10:09:15 -05:00
|
|
|
```shell
|
2019-06-07 04:00:41 -04:00
|
|
|
sudo service gitlab restart
|
|
|
|
```
|
2016-01-06 14:05:22 -05:00
|
|
|
|
|
|
|
For Omnibus installations, edit `/etc/gitlab/gitlab.rb` and add the line:
|
|
|
|
|
2019-06-07 04:00:41 -04:00
|
|
|
```ruby
|
2016-03-11 14:26:18 -05:00
|
|
|
gitlab_rails['gitlab_default_projects_features_builds'] = false
|
2016-01-06 14:05:22 -05:00
|
|
|
```
|
|
|
|
|
2019-06-07 04:00:41 -04:00
|
|
|
Save the file and reconfigure GitLab:
|
|
|
|
|
2020-01-30 10:09:15 -05:00
|
|
|
```shell
|
2019-06-07 04:00:41 -04:00
|
|
|
sudo gitlab-ctl reconfigure
|
|
|
|
```
|
|
|
|
|
|
|
|
<!-- ## Troubleshooting
|
|
|
|
|
|
|
|
Include any troubleshooting steps that you can foresee. If you know beforehand what issues
|
|
|
|
one might have when setting this up, or when something is changed, or on upgrading, it's
|
|
|
|
important to describe those, too. Think of things that may go wrong and include them here.
|
|
|
|
This is important to minimize requests for support, and to avoid doc comments with
|
|
|
|
questions that you know someone might ask.
|
|
|
|
|
|
|
|
Each scenario can be a third-level heading, e.g. `### Getting error message X`.
|
|
|
|
If you have none to add when creating a doc, leave this section in place
|
|
|
|
but commented out to help encourage others to add to it in the future. -->
|