2017-10-06 05:20:52 -04:00
|
|
|
---
|
2018-02-07 17:43:08 -05:00
|
|
|
last_updated: 2018-02-07
|
2017-10-06 05:20:52 -04:00
|
|
|
---
|
2017-09-12 18:14:01 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
# Migrating from MySQL to PostgreSQL
|
2014-05-08 07:18:12 -04:00
|
|
|
|
2018-02-07 17:43:08 -05:00
|
|
|
> **Note:** This guide assumes you have a working GitLab instance with
|
2017-10-06 05:20:52 -04:00
|
|
|
> MySQL and want to migrate to bundled PostgreSQL database.
|
2014-03-17 09:55:56 -04:00
|
|
|
|
2018-02-07 17:43:08 -05:00
|
|
|
## Omnibus installation
|
|
|
|
|
|
|
|
### Prerequisites
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
First, we'll need to enable the bundled PostgreSQL database with up-to-date
|
|
|
|
schema. Next, we'll use [pgloader](http://pgloader.io) to migrate the data
|
|
|
|
from the old MySQL database to the new PostgreSQL one.
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
Here's what you'll need to have installed:
|
2014-05-08 07:18:22 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
- pgloader 3.4.1+
|
|
|
|
- Omnibus GitLab
|
|
|
|
- MySQL
|
2014-05-08 07:18:22 -04:00
|
|
|
|
2018-02-07 17:43:08 -05:00
|
|
|
### Enable bundled PostgreSQL database
|
2014-05-19 12:28:45 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
1. Stop GitLab:
|
2014-05-19 11:51:58 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
``` bash
|
|
|
|
sudo gitlab-ctl stop
|
|
|
|
```
|
2014-09-09 17:55:45 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
1. Edit `/etc/gitlab/gitlab.rb` to enable bundled PostgreSQL:
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
```
|
|
|
|
postgresql['enable'] = true
|
|
|
|
```
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
1. Edit `/etc/gitlab/gitlab.rb` to use the bundled PostgreSQL. Please check
|
|
|
|
all the settings beginning with `db_`, such as `gitlab_rails['db_adapter']`
|
|
|
|
and alike. You could just comment all of them out so that we'll just use
|
|
|
|
the defaults.
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
1. [Reconfigure GitLab] for the changes to take effect:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
sudo gitlab-ctl reconfigure
|
|
|
|
```
|
|
|
|
|
2017-10-06 12:51:29 -04:00
|
|
|
1. Start Unicorn and PostgreSQL so that we can prepare the schema:
|
2017-10-06 05:20:52 -04:00
|
|
|
|
|
|
|
``` bash
|
|
|
|
sudo gitlab-ctl start unicorn
|
2017-10-06 12:51:29 -04:00
|
|
|
sudo gitlab-ctl start postgresql
|
2017-10-06 05:20:52 -04:00
|
|
|
```
|
|
|
|
|
|
|
|
1. Run the following commands to prepare the schema:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
sudo gitlab-rake db:create db:migrate
|
|
|
|
```
|
|
|
|
|
2017-10-06 12:51:29 -04:00
|
|
|
1. Stop Unicorn to prevent other database access from interfering with the loading of data:
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
``` bash
|
|
|
|
sudo gitlab-ctl stop unicorn
|
|
|
|
```
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
After these steps, you'll have a fresh PostgreSQL database with up-to-date schema.
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2018-02-07 17:43:08 -05:00
|
|
|
### Migrate data from MySQL to PostgreSQL
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
Now, you can use pgloader to migrate the data from MySQL to PostgreSQL:
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
1. Save the following snippet in a `commands.load` file, and edit with your
|
|
|
|
database `username`, `password` and `host`:
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
```
|
|
|
|
LOAD DATABASE
|
|
|
|
FROM mysql://username:password@host/gitlabhq_production
|
|
|
|
INTO postgresql://gitlab-psql@unix://var/opt/gitlab/postgresql:/gitlabhq_production
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
WITH include no drop, truncate, disable triggers, create no tables,
|
|
|
|
create no indexes, preserve index names, no foreign keys,
|
|
|
|
data only
|
2015-06-23 09:45:24 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
ALTER SCHEMA 'gitlabhq_production' RENAME TO 'public'
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
;
|
|
|
|
```
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
1. Start the migration:
|
2014-05-08 06:10:04 -04:00
|
|
|
|
2017-10-06 05:20:52 -04:00
|
|
|
``` bash
|
|
|
|
sudo -u gitlab-psql pgloader commands.load
|
|
|
|
```
|
|
|
|
|
2017-10-06 12:51:29 -04:00
|
|
|
1. Once the migration finishes, you should see a summary table that looks like
|
2019-02-22 08:17:10 -05:00
|
|
|
the following:
|
2017-10-06 12:51:29 -04:00
|
|
|
|
|
|
|
```
|
|
|
|
table name read imported errors total time
|
|
|
|
----------------------------------------------- --------- --------- --------- --------------
|
|
|
|
fetch meta data 119 119 0 0.388s
|
|
|
|
Truncate 119 119 0 1.134s
|
|
|
|
----------------------------------------------- --------- --------- --------- --------------
|
|
|
|
public.abuse_reports 0 0 0 0.490s
|
|
|
|
public.appearances 0 0 0 0.488s
|
2018-02-07 17:43:08 -05:00
|
|
|
.
|
|
|
|
.
|
|
|
|
.
|
2017-10-06 12:51:29 -04:00
|
|
|
public.web_hook_logs 0 0 0 1.080s
|
|
|
|
----------------------------------------------- --------- --------- --------- --------------
|
|
|
|
COPY Threads Completion 4 4 0 2.008s
|
|
|
|
Reset Sequences 113 113 0 0.304s
|
|
|
|
Install Comments 0 0 0 0.000s
|
|
|
|
----------------------------------------------- --------- --------- --------- --------------
|
|
|
|
Total import time 1894 1894 0 12.497s
|
|
|
|
```
|
|
|
|
|
|
|
|
If there is no output for more than 30 minutes, it's possible pgloader encountered an error. See
|
|
|
|
the [troubleshooting guide](#Troubleshooting) for more details.
|
|
|
|
|
|
|
|
1. Start GitLab:
|
2017-10-06 05:20:52 -04:00
|
|
|
|
|
|
|
``` bash
|
|
|
|
sudo gitlab-ctl start
|
|
|
|
```
|
|
|
|
|
|
|
|
Now, you can verify that everything worked by visiting GitLab.
|
|
|
|
|
2018-02-07 17:43:08 -05:00
|
|
|
### Troubleshooting
|
2017-10-06 05:20:52 -04:00
|
|
|
|
2018-02-07 17:43:08 -05:00
|
|
|
#### Permissions
|
2017-10-06 12:51:29 -04:00
|
|
|
|
|
|
|
Note that the PostgreSQL user that you use for the above MUST have **superuser** privileges. Otherwise, you may see
|
|
|
|
a similar message to the following:
|
|
|
|
|
|
|
|
```
|
|
|
|
debugger invoked on a CL-POSTGRES-ERROR:INSUFFICIENT-PRIVILEGE in thread
|
|
|
|
#<THREAD "lparallel" RUNNING {10078A3513}>:
|
|
|
|
Database error 42501: permission denied: "RI_ConstraintTrigger_a_20937" is a system trigger
|
|
|
|
QUERY: ALTER TABLE ci_builds DISABLE TRIGGER ALL;
|
|
|
|
2017-08-23T00:36:56.782000Z ERROR Database error 42501: permission denied: "RI_ConstraintTrigger_c_20864" is a system trigger
|
|
|
|
QUERY: ALTER TABLE approver_groups DISABLE TRIGGER ALL;
|
|
|
|
```
|
|
|
|
|
2018-02-07 17:43:08 -05:00
|
|
|
#### Experiencing 500 errors after the migration
|
2017-10-06 05:20:52 -04:00
|
|
|
|
|
|
|
If you experience 500 errors after the migration, try to clear the cache:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
sudo gitlab-rake cache:clear
|
2014-05-08 06:10:04 -04:00
|
|
|
```
|
2017-10-06 05:20:52 -04:00
|
|
|
|
|
|
|
[reconfigure GitLab]: ../administration/restart_gitlab.md#omnibus-gitlab-reconfigure
|
2018-02-07 17:43:08 -05:00
|
|
|
|
|
|
|
## Source installation
|
|
|
|
|
|
|
|
### Prerequisites
|
|
|
|
|
|
|
|
#### Install PostgreSQL and create database
|
|
|
|
|
|
|
|
See [installation guide](../install/installation.md#6-database).
|
|
|
|
|
|
|
|
#### Install [pgloader](http://pgloader.io) 3.4.1+
|
|
|
|
|
|
|
|
Install directly from your distro:
|
|
|
|
``` bash
|
|
|
|
sudo apt-get install pgloader
|
|
|
|
```
|
|
|
|
|
|
|
|
If this version is too old, use PostgreSQL's repository:
|
|
|
|
``` bash
|
|
|
|
# add repository
|
|
|
|
sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt/ $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list'
|
|
|
|
|
|
|
|
# add key
|
|
|
|
sudo apt-get install wget ca-certificates
|
|
|
|
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
|
|
|
|
|
|
|
|
# install package
|
|
|
|
sudo apt-get update
|
|
|
|
sudo apt-get install pgloader
|
|
|
|
```
|
|
|
|
|
|
|
|
### Enable bundled PostgreSQL database
|
|
|
|
|
|
|
|
1. Stop GitLab:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
sudo service gitlab stop
|
|
|
|
```
|
|
|
|
|
|
|
|
1. Switch database from MySQL to PostgreSQL
|
|
|
|
|
2018-07-20 03:45:36 -04:00
|
|
|
``` bash
|
|
|
|
cd /home/git/gitlab
|
|
|
|
sudo -u git mv config/database.yml config/database.yml.bak
|
|
|
|
sudo -u git cp config/database.yml.postgresql config/database.yml
|
|
|
|
sudo -u git -H chmod o-rwx config/database.yml
|
|
|
|
```
|
2018-07-20 10:00:53 -04:00
|
|
|
1. Install Gems related to Postgresql
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
sudo -u git -H rm .bundle/config
|
|
|
|
sudo -u git -H bundle install --deployment --without development test mysql aws kerberos
|
|
|
|
```
|
2018-02-07 17:43:08 -05:00
|
|
|
|
|
|
|
1. Run the following commands to prepare the schema:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
sudo -u git -H bundle exec rake db:create db:migrate RAILS_ENV=production
|
|
|
|
```
|
|
|
|
|
|
|
|
After these steps, you'll have a fresh PostgreSQL database with up-to-date schema.
|
|
|
|
|
|
|
|
### Migrate data from MySQL to PostgreSQL
|
|
|
|
|
|
|
|
Now, you can use pgloader to migrate the data from MySQL to PostgreSQL:
|
|
|
|
|
|
|
|
1. Save the following snippet in a `commands.load` file, and edit with your
|
|
|
|
MySQL `username`, `password` and `host`:
|
|
|
|
|
|
|
|
```
|
|
|
|
LOAD DATABASE
|
|
|
|
FROM mysql://username:password@host/gitlabhq_production
|
|
|
|
INTO postgresql://postgres@unix://var/run/postgresql:/gitlabhq_production
|
|
|
|
|
|
|
|
WITH include no drop, truncate, disable triggers, create no tables,
|
|
|
|
create no indexes, preserve index names, no foreign keys,
|
|
|
|
data only
|
|
|
|
|
|
|
|
ALTER SCHEMA 'gitlabhq_production' RENAME TO 'public'
|
|
|
|
|
|
|
|
;
|
|
|
|
```
|
|
|
|
|
|
|
|
1. Start the migration:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
sudo -u postgres pgloader commands.load
|
|
|
|
```
|
|
|
|
|
|
|
|
1. Once the migration finishes, you should see a summary table that looks like
|
2019-02-22 08:17:10 -05:00
|
|
|
the following:
|
2018-02-07 17:43:08 -05:00
|
|
|
|
|
|
|
```
|
|
|
|
table name read imported errors total time
|
|
|
|
----------------------------------------------- --------- --------- --------- --------------
|
|
|
|
fetch meta data 119 119 0 0.388s
|
|
|
|
Truncate 119 119 0 1.134s
|
|
|
|
----------------------------------------------- --------- --------- --------- --------------
|
|
|
|
public.abuse_reports 0 0 0 0.490s
|
|
|
|
public.appearances 0 0 0 0.488s
|
|
|
|
.
|
|
|
|
.
|
|
|
|
.
|
|
|
|
public.web_hook_logs 0 0 0 1.080s
|
|
|
|
----------------------------------------------- --------- --------- --------- --------------
|
|
|
|
COPY Threads Completion 4 4 0 2.008s
|
|
|
|
Reset Sequences 113 113 0 0.304s
|
|
|
|
Install Comments 0 0 0 0.000s
|
|
|
|
----------------------------------------------- --------- --------- --------- --------------
|
|
|
|
Total import time 1894 1894 0 12.497s
|
|
|
|
```
|
|
|
|
|
|
|
|
If there is no output for more than 30 minutes, it's possible pgloader encountered an error. See
|
|
|
|
the [troubleshooting guide](#Troubleshooting) for more details.
|
|
|
|
|
|
|
|
1. Start GitLab:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
sudo service gitlab start
|
|
|
|
```
|
|
|
|
|
|
|
|
Now, you can verify that everything worked by visiting GitLab.
|
|
|
|
|
|
|
|
### Troubleshooting
|
|
|
|
|
|
|
|
#### Experiencing 500 errors after the migration
|
|
|
|
|
|
|
|
If you experience 500 errors after the migration, try to clear the cache:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
sudo -u git -H bundle exec rake cache:clear RAILS_ENV=production
|
|
|
|
```
|