gitlab-org--gitlab-foss/doc/ci/enable_or_disable_ci.md

70 lines
2.3 KiB
Markdown
Raw Normal View History

2019-05-27 19:53:21 +00:00
---
type: reference
---
2017-11-01 15:56:40 +00:00
# How to enable or disable GitLab CI/CD
2017-10-03 13:11:49 +00: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 and a
[runner](runners/README.md) properly set up. You can read our
2017-10-03 13:11:49 +00:00
[quick start guide](quick_start/README.md) to get you started.
2017-10-03 13:11:49 +00: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
API.
---
2017-10-03 13:11:49 +00: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
it's hidden from the left sidebar menu.
2017-10-03 13:11:49 +00:00
GitLab CI/CD is enabled by default on new installations and can be disabled either
2016-01-07 09:10:46 +00:00
individually under each project's settings, or site-wide by modifying the
settings in `gitlab.yml` and `gitlab.rb` for source and Omnibus installations
respectively.
2017-11-01 15:56:40 +00:00
## Per-project user setting
2017-10-03 13:11:49 +00:00
The setting to enable or disable GitLab CI/CD can be found under your project's
**Settings > General > Permissions**. Choose one of "Disabled", "Only team members"
or "Everyone with access" and hit **Save changes** for the settings to take effect.
2017-10-03 13:11:49 +00:00
![Sharing & Permissions settings](../user/project/settings/img/sharing_and_permissions_settings.png)
2017-11-01 15:56:40 +00:00
## Site-wide admin setting
2017-10-03 13:11:49 +00:00
You can disable GitLab CI/CD site-wide, by modifying the settings in `gitlab.yml`
and `gitlab.rb` for source and Omnibus installations respectively.
2016-01-07 09:10:46 +00:00
Two things to note:
2017-10-03 13:11:49 +00:00
1. Disabling GitLab CI/CD, will affect only newly-created projects. Projects that
2016-01-07 09:10:46 +00:00
had it enabled prior to this modification, will work as before.
2017-10-03 13:11:49 +00:00
1. Even if you disable GitLab CI/CD, users will still be able to enable it in the
project's settings.
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
```
Save the file and restart GitLab: `sudo service gitlab restart`.
For Omnibus installations, edit `/etc/gitlab/gitlab.rb` and add the line:
```
gitlab_rails['gitlab_default_projects_features_builds'] = false
```
Save the file and reconfigure GitLab: `sudo gitlab-ctl reconfigure`.