2019-09-04 21:01:54 +05:30
|
|
|
---
|
|
|
|
type: howto
|
|
|
|
---
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
# How to enable or disable GitLab CI/CD
|
2016-01-14 18:37:52 +05:30
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
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-14 18:37:52 +05:30
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
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-14 18:37:52 +05:30
|
|
|
API.
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
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-08-17 22:00:37 +05:30
|
|
|
it's hidden from the left sidebar menu.
|
2016-01-14 18:37:52 +05:30
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
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-14 18:37:52 +05:30
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
## Per-project user setting
|
2016-01-14 18:37:52 +05:30
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
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.
|
2016-01-14 18:37:52 +05:30
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
![Sharing & Permissions settings](../user/project/settings/img/sharing_and_permissions_settings.png)
|
2016-01-14 18:37:52 +05:30
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
## Site-wide admin setting
|
2016-01-14 18:37:52 +05:30
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
You can disable GitLab CI/CD site-wide, by modifying the settings in `gitlab.yml`
|
2016-01-14 18:37:52 +05:30
|
|
|
and `gitlab.rb` for source and Omnibus installations respectively.
|
|
|
|
|
|
|
|
Two things to note:
|
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
- 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-14 18:37:52 +05:30
|
|
|
|
|
|
|
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-09-04 21:01:54 +05:30
|
|
|
Save the file and restart GitLab:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
sudo service gitlab restart
|
|
|
|
```
|
2016-01-14 18:37:52 +05:30
|
|
|
|
|
|
|
For Omnibus installations, edit `/etc/gitlab/gitlab.rb` and add the line:
|
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
```ruby
|
2016-06-02 11:05:42 +05:30
|
|
|
gitlab_rails['gitlab_default_projects_features_builds'] = false
|
2016-01-14 18:37:52 +05:30
|
|
|
```
|
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
Save the file and reconfigure GitLab:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
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. -->
|