Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Jérome Perrin
gitlab-ce
Commits
5234d181
Commit
5234d181
authored
Apr 26, 2017
by
Marcia Ramos
Committed by
Achilleas Pipinellis
Apr 26, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Reorg CE Docs landing page
parent
8fbda3bf
Changes
3
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
214 additions
and
95 deletions
+214
-95
doc/README.md
doc/README.md
+181
-66
doc/migrate_ci_to_ce/README.md
doc/migrate_ci_to_ce/README.md
+29
-29
doc/topics/git/index.md
doc/topics/git/index.md
+4
-0
No files found.
doc/README.md
View file @
5234d181
This diff is collapsed.
Click to expand it.
doc/migrate_ci_to_ce/README.md
View file @
5234d181
#
#
Migrate GitLab CI to GitLab CE or EE
# Migrate GitLab CI to GitLab CE or EE
Beginning with version 8.0 of GitLab Community Edition (CE) and Enterprise
Beginning with version 8.0 of GitLab Community Edition (CE) and Enterprise
Edition (EE), GitLab CI is no longer its own application, but is instead built
Edition (EE), GitLab CI is no longer its own application, but is instead built
...
@@ -12,7 +12,7 @@ is not possible.**
...
@@ -12,7 +12,7 @@ is not possible.**
We recommend that you read through the entire migration process in this
We recommend that you read through the entire migration process in this
document before beginning.
document before beginning.
##
#
Overview
## Overview
In this document we assume you have a GitLab server and a GitLab CI server. It
In this document we assume you have a GitLab server and a GitLab CI server. It
does not matter if these are the same machine.
does not matter if these are the same machine.
...
@@ -26,7 +26,7 @@ can be online for most of the procedure; the only GitLab downtime (if any) is
...
@@ -26,7 +26,7 @@ can be online for most of the procedure; the only GitLab downtime (if any) is
during the upgrade to 8.0. Your CI service will be offline from the moment you
during the upgrade to 8.0. Your CI service will be offline from the moment you
upgrade to 8.0 until you finish the migration procedure.
upgrade to 8.0 until you finish the migration procedure.
##
#
Before upgrading
## Before upgrading
If you have GitLab CI installed using omnibus-gitlab packages but
**you don't want to migrate your existing data**
:
If you have GitLab CI installed using omnibus-gitlab packages but
**you don't want to migrate your existing data**
:
...
@@ -38,12 +38,12 @@ run `sudo gitlab-ctl reconfigure` and you can reach CI at `gitlab.example.com/ci
...
@@ -38,12 +38,12 @@ run `sudo gitlab-ctl reconfigure` and you can reach CI at `gitlab.example.com/ci
If you want to migrate your existing data, continue reading.
If you want to migrate your existing data, continue reading.
###
#
0. Updating Omnibus from versions prior to 7.13
### 0. Updating Omnibus from versions prior to 7.13
If you are updating from older versions you should first update to 7.14 and then to 8.0.
If you are updating from older versions you should first update to 7.14 and then to 8.0.
Otherwise it's pretty likely that you will encounter problems described in the
[
Troubleshooting
](
#troubleshooting
)
.
Otherwise it's pretty likely that you will encounter problems described in the
[
Troubleshooting
](
#troubleshooting
)
.
###
#
1. Verify that backups work
### 1. Verify that backups work
Make sure that the backup script on both servers can connect to the database.
Make sure that the backup script on both servers can connect to the database.
...
@@ -73,7 +73,7 @@ sudo -u git -H bundle exec rake gitlab:backup:create RAILS_ENV=production SKIP=r
...
@@ -73,7 +73,7 @@ sudo -u git -H bundle exec rake gitlab:backup:create RAILS_ENV=production SKIP=r
If this fails you need to fix it before upgrading to 8.0. Also see
If this fails you need to fix it before upgrading to 8.0. Also see
https://about.gitlab.com/getting-help/
https://about.gitlab.com/getting-help/
###
#
2. Check source and target database types
### 2. Check source and target database types
Check what databases you use on your GitLab server and your CI server.
Check what databases you use on your GitLab server and your CI server.
Look for the 'adapter:' line. If your CI server and your GitLab server use
Look for the 'adapter:' line. If your CI server and your GitLab server use
...
@@ -102,7 +102,7 @@ cd /home/git/gitlab
...
@@ -102,7 +102,7 @@ cd /home/git/gitlab
sudo -u git -H bundle exec rake gitlab:env:info RAILS_ENV=production
sudo -u git -H bundle exec rake gitlab:env:info RAILS_ENV=production
```
```
###
#
3. Storage planning
### 3. Storage planning
Decide where to store CI build traces on GitLab server. GitLab CI uses
Decide where to store CI build traces on GitLab server. GitLab CI uses
files on disk to store CI build traces. The default path for these build
files on disk to store CI build traces. The default path for these build
...
@@ -111,34 +111,34 @@ traces is `/var/opt/gitlab/gitlab-ci/builds` (Omnibus) or
...
@@ -111,34 +111,34 @@ traces is `/var/opt/gitlab/gitlab-ci/builds` (Omnibus) or
a special location, or if you are using NFS, you should make sure that you
a special location, or if you are using NFS, you should make sure that you
store build traces on the same storage as your Git repositories.
store build traces on the same storage as your Git repositories.
##
#
I. Upgrading
## I. Upgrading
From this point on, GitLab CI will be unavailable for your end users.
From this point on, GitLab CI will be unavailable for your end users.
###
#
1. Upgrade GitLab to 8.0
### 1. Upgrade GitLab to 8.0
First upgrade your GitLab server to version 8.0:
First upgrade your GitLab server to version 8.0:
https://about.gitlab.com/update/
https://about.gitlab.com/update/
###
#
2. Disable CI on the GitLab server during the migration
### 2. Disable CI on the GitLab server during the migration
After you update, go to the admin panel and temporarily disable CI. As
After you update, go to the admin panel and temporarily disable CI. As
an administrator, go to
**Admin Area**
->
**Settings**
, and under
an administrator, go to
**Admin Area**
->
**Settings**
, and under
**Continuous Integration**
uncheck
**
Disable to prevent CI usage until rake
**Continuous Integration**
uncheck
**
Disable to prevent CI usage until rake
ci:migrate is run (8.0 only)
**
.
ci:migrate is run (8.0 only)
**
.
###
#
3. CI settings are now in GitLab
### 3. CI settings are now in GitLab
If you want to use custom CI settings (e.g. change where builds are
If you want to use custom CI settings (e.g. change where builds are
stored), please update
`/etc/gitlab/gitlab.rb`
(Omnibus) or
stored), please update
`/etc/gitlab/gitlab.rb`
(Omnibus) or
`/home/git/gitlab/config/gitlab.yml`
(Source).
`/home/git/gitlab/config/gitlab.yml`
(Source).
###
#
4. Upgrade GitLab CI to 8.0
### 4. Upgrade GitLab CI to 8.0
Now upgrade GitLab CI to version 8.0. If you are using Omnibus packages,
Now upgrade GitLab CI to version 8.0. If you are using Omnibus packages,
this may have already happened when you upgraded GitLab to 8.0.
this may have already happened when you upgraded GitLab to 8.0.
###
#
5. Disable GitLab CI on the CI server
### 5. Disable GitLab CI on the CI server
Disable GitLab CI after upgrading to 8.0.
Disable GitLab CI after upgrading to 8.0.
...
@@ -154,9 +154,9 @@ cd /home/gitlab_ci/gitlab-ci
...
@@ -154,9 +154,9 @@ cd /home/gitlab_ci/gitlab-ci
sudo -u gitlab_ci -H bundle exec whenever --clear-crontab RAILS_ENV=production
sudo -u gitlab_ci -H bundle exec whenever --clear-crontab RAILS_ENV=production
```
```
##
#
II. Moving data
## II. Moving data
###
#
1. Database encryption key
### 1. Database encryption key
Move the database encryption key from your CI server to your GitLab
Move the database encryption key from your CI server to your GitLab
server. The command below will show you what you need to copy-paste to your
server. The command below will show you what you need to copy-paste to your
...
@@ -174,7 +174,7 @@ cd /home/gitlab_ci/gitlab-ci
...
@@ -174,7 +174,7 @@ cd /home/gitlab_ci/gitlab-ci
sudo -u gitlab_ci -H bundle exec rake backup:show_secrets RAILS_ENV=production
sudo -u gitlab_ci -H bundle exec rake backup:show_secrets RAILS_ENV=production
```
```
###
#
2. SQL data and build traces
### 2. SQL data and build traces
Create your final CI data export. If you are converting from MySQL to
Create your final CI data export. If you are converting from MySQL to
PostgreSQL, add
` MYSQL_TO_POSTGRESQL=1`
to the end of the rake command. When
PostgreSQL, add
` MYSQL_TO_POSTGRESQL=1`
to the end of the rake command. When
...
@@ -192,7 +192,7 @@ cd /home/gitlab_ci/gitlab-ci
...
@@ -192,7 +192,7 @@ cd /home/gitlab_ci/gitlab-ci
sudo -u gitlab_ci -H bundle exec rake backup:create RAILS_ENV=production
sudo -u gitlab_ci -H bundle exec rake backup:create RAILS_ENV=production
```
```
###
#
3. Copy data to the GitLab server
### 3. Copy data to the GitLab server
If you were running GitLab and GitLab CI on the same server you can skip this
If you were running GitLab and GitLab CI on the same server you can skip this
step.
step.
...
@@ -209,7 +209,7 @@ ssh -A ci_admin@ci_server.example
...
@@ -209,7 +209,7 @@ ssh -A ci_admin@ci_server.example
scp /path/to/12345_gitlab_ci_backup.tar gitlab_admin@gitlab_server.example:~
scp /path/to/12345_gitlab_ci_backup.tar gitlab_admin@gitlab_server.example:~
```
```
###
#
4. Move data to the GitLab backups folder
### 4. Move data to the GitLab backups folder
Make the CI data archive discoverable for GitLab. We assume below that you
Make the CI data archive discoverable for GitLab. We assume below that you
store backups in the default path, adjust the command if necessary.
store backups in the default path, adjust the command if necessary.
...
@@ -223,7 +223,7 @@ sudo mv /path/to/12345_gitlab_ci_backup.tar /var/opt/gitlab/backups/
...
@@ -223,7 +223,7 @@ sudo mv /path/to/12345_gitlab_ci_backup.tar /var/opt/gitlab/backups/
sudo mv /path/to/12345_gitlab_ci_backup.tar /home/git/gitlab/tmp/backups/
sudo mv /path/to/12345_gitlab_ci_backup.tar /home/git/gitlab/tmp/backups/
```
```
###
#
5. Import the CI data into GitLab.
### 5. Import the CI data into GitLab.
This step will delete any existing CI data on your GitLab server. There should
This step will delete any existing CI data on your GitLab server. There should
be no CI data yet because you turned CI on the GitLab server off earlier.
be no CI data yet because you turned CI on the GitLab server off earlier.
...
@@ -239,7 +239,7 @@ cd /home/git/gitlab
...
@@ -239,7 +239,7 @@ cd /home/git/gitlab
sudo -u git -H bundle exec rake ci:migrate RAILS_ENV=production
sudo -u git -H bundle exec rake ci:migrate RAILS_ENV=production
```
```
###
#
6. Restart GitLab
### 6. Restart GitLab
```
```
# On your GitLab server:
# On your GitLab server:
...
@@ -251,7 +251,7 @@ sudo gitlab-ctl restart sidekiq
...
@@ -251,7 +251,7 @@ sudo gitlab-ctl restart sidekiq
sudo service gitlab reload
sudo service gitlab reload
```
```
##
#
III. Redirecting traffic
## III. Redirecting traffic
If you were running GitLab CI with Omnibus packages and you were using the
If you were running GitLab CI with Omnibus packages and you were using the
internal NGINX configuration your CI service should now be available both at
internal NGINX configuration your CI service should now be available both at
...
@@ -261,7 +261,7 @@ If you installed GitLab CI from source we now need to configure a redirect in
...
@@ -261,7 +261,7 @@ If you installed GitLab CI from source we now need to configure a redirect in
NGINX so that existing CI runners can keep using the old CI server address, and
NGINX so that existing CI runners can keep using the old CI server address, and
so that existing links to your CI server keep working.
so that existing links to your CI server keep working.
###
#
1. Update Nginx configuration
### 1. Update Nginx configuration
To ensure that your existing CI runners are able to communicate with the
To ensure that your existing CI runners are able to communicate with the
migrated installation, and that existing build triggers still work, you'll need
migrated installation, and that existing build triggers still work, you'll need
...
@@ -317,22 +317,22 @@ You should also make sure that you can:
...
@@ -317,22 +317,22 @@ You should also make sure that you can:
1.
`curl https://YOUR_GITLAB_SERVER_FQDN/`
from your previous GitLab CI server.
1.
`curl https://YOUR_GITLAB_SERVER_FQDN/`
from your previous GitLab CI server.
1.
`curl https://YOUR_CI_SERVER_FQDN/`
from your GitLab CE (or EE) server.
1.
`curl https://YOUR_CI_SERVER_FQDN/`
from your GitLab CE (or EE) server.
###
#
2. Check Nginx configuration
### 2. Check Nginx configuration
sudo nginx -t
sudo nginx -t
###
#
3. Restart Nginx
### 3. Restart Nginx
sudo /etc/init.d/nginx restart
sudo /etc/init.d/nginx restart
###
#
Restore from backup
### Restore from backup
If something went wrong and you need to restore a backup, consult the
[
Backup
If something went wrong and you need to restore a backup, consult the
[
Backup
restoration
](
../raketasks/backup_restore.md
)
guide.
restoration
](
../raketasks/backup_restore.md
)
guide.
##
#
Troubleshooting
## Troubleshooting
###
#
show:secrets problem (Omnibus-only)
### show:secrets problem (Omnibus-only)
If you see errors like this:
If you see errors like this:
```
```
Missing `secret_key_base` or `db_key_base` for 'production' environment. The secrets will be generated and stored in `config/secrets.yml`
Missing `secret_key_base` or `db_key_base` for 'production' environment. The secrets will be generated and stored in `config/secrets.yml`
...
@@ -343,7 +343,7 @@ Errno::EACCES: Permission denied @ rb_sysopen - config/secrets.yml
...
@@ -343,7 +343,7 @@ Errno::EACCES: Permission denied @ rb_sysopen - config/secrets.yml
This can happen if you are updating from versions prior to 7.13 straight to 8.0.
This can happen if you are updating from versions prior to 7.13 straight to 8.0.
The fix for this is to update to Omnibus 7.14 first and then update it to 8.0.
The fix for this is to update to Omnibus 7.14 first and then update it to 8.0.
###
#
Permission denied when accessing /var/opt/gitlab/gitlab-ci/builds
### Permission denied when accessing /var/opt/gitlab/gitlab-ci/builds
To fix that issue you have to change builds/ folder permission before doing final backup:
To fix that issue you have to change builds/ folder permission before doing final backup:
```
```
sudo chown -R gitlab-ci:gitlab-ci /var/opt/gitlab/gitlab-ci/builds
sudo chown -R gitlab-ci:gitlab-ci /var/opt/gitlab/gitlab-ci/builds
...
@@ -354,7 +354,7 @@ Then before executing `ci:migrate` you need to fix builds folder permission:
...
@@ -354,7 +354,7 @@ Then before executing `ci:migrate` you need to fix builds folder permission:
sudo chown git:git /var/opt/gitlab/gitlab-ci/builds
sudo chown git:git /var/opt/gitlab/gitlab-ci/builds
```
```
###
#
Problems when importing CI database to GitLab
### Problems when importing CI database to GitLab
If you were migrating CI database from MySQL to PostgreSQL manually you can see errors during import about missing sequences:
If you were migrating CI database from MySQL to PostgreSQL manually you can see errors during import about missing sequences:
```
```
ALTER SEQUENCE
ALTER SEQUENCE
...
...
doc/topics/git/index.md
View file @
5234d181
...
@@ -17,6 +17,10 @@ We've gathered some resources to help you to get the best from Git with GitLab.
...
@@ -17,6 +17,10 @@ We've gathered some resources to help you to get the best from Git with GitLab.
-
[
Start using Git on the command line
](
../../gitlab-basics/start-using-git.md
)
-
[
Start using Git on the command line
](
../../gitlab-basics/start-using-git.md
)
-
[
Command Line basic commands
](
../../gitlab-basics/command-line-commands.md
)
-
[
Command Line basic commands
](
../../gitlab-basics/command-line-commands.md
)
-
[
GitLab Git Cheat Sheet (download)
](
https://gitlab.com/gitlab-com/marketing/raw/master/design/print/git-cheatsheet/print-pdf/git-cheatsheet.pdf
)
-
[
GitLab Git Cheat Sheet (download)
](
https://gitlab.com/gitlab-com/marketing/raw/master/design/print/git-cheatsheet/print-pdf/git-cheatsheet.pdf
)
-
Commits
-
[
Revert a commit
](
../../user/project/merge_requests/revert_changes.md#reverting-a-commit
)
-
[
Cherry-picking a commit
](
../../user/project/merge_requests/cherry_pick_changes.md#cherry-picking-a-commit
)
-
[
Squashing commits
](
../../workflow/gitlab_flow.md#squashing-commits-with-rebase
)
-
**Articles:**
-
**Articles:**
-
[
Git Tips & Tricks
](
https://about.gitlab.com/2016/12/08/git-tips-and-tricks/
)
-
[
Git Tips & Tricks
](
https://about.gitlab.com/2016/12/08/git-tips-and-tricks/
)
-
[
Eight Tips to help you work better with Git
](
https://about.gitlab.com/2015/02/19/8-tips-to-help-you-work-better-with-git/
)
-
[
Eight Tips to help you work better with Git
](
https://about.gitlab.com/2015/02/19/8-tips-to-help-you-work-better-with-git/
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment