Миграция на GitLab база данни към външен PostgreSQL

Здравейте на всички!

В тази статия ще мигрираме базата данни на GitLab от вътрешен PostgreSQL, който е инсталиран с GitLab, към външен PostgreSQL, който вече е инсталиран на друг сървър.

Миграция на GitLab база данни към външен PostgreSQL

ЗАБЕЛЕЖКА
Гарантирано е, че всички действия работят на CentOS 7.7.1908, PostgreSQL 12 и GitLab 12.4.2-ee.0.

Предварителна подготовка

Нека направим три неща предварително:

1. На сървъра на PostgreSQL добавете правило към защитната стена, което позволява входящи връзки към порт 5432/TCP на PostgreSQL.

В моя случай:

firewall-cmd --add-service=postgresql --zone=internal --permanent
success
firewall-cmd --reload
success

2. На същото място, но във файла postgresql.conf, позволете на мрежовия интерфейс да приема входящи връзки отвън. Отворете файла postgresql.conf, намерете коментирания ред "#listen_addresses = 'localhost'" и под него добавете ред като по-долу. Къде - 10.0.0.2, адресът на вашия интерфейс.

В моя случай:

vi /var/lib/pgsql/12/data/postgresql.conf
# - Connection Settings -

#listen_addresses = 'localhost'         # what IP address(es) to listen on;
listen_addresses = 'localhost, 10.0.0.2'
                                        # comma-separated list of addresses;

3. Тъй като GitLab сървърът ще се свърже с външна база данни, това трябва да бъде разрешено на PostgreSQL сървъра във файла pg_hba.conf. Адресът на моя GitLab сървър е 10.0.0.4.

Нека отворим файла pg_hba.conf и добавим реда там:

host    all             gitlab               10.0.0.4/24             md5

Ще изглежда така:

# TYPE  DATABASE        USER            ADDRESS                 METHOD

# "local" is for Unix domain socket connections only
local   all             postgres                                     md5

# IPv4 local connections:
host    all             postgres             127.0.0.1/32            md5
host    all             gitlab               10.0.0.4/24             md5

И накрая, рестартираме услугата postgresql:

systemctl restart postgresql-12.service

Експортиране на база данни на GitLab

Нека направим резервно копие на база данни на сървъра GitLab:

sudo -u gitlab-psql /opt/gitlab/embedded/bin/pg_dumpall -U gitlab-psql --host=/var/opt/gitlab/postgresql > /tmp/internal-gitlab.sql

Архивът се появи в /tmp:

ls -lh
total 836K
-rw-r--r--. 1 root root 836K Nov 18 12:59 internal-gitlab.sql

Нека копираме това копие на сървъра на PostgreSQL:

scp /tmp/internal-gitlab.sql 10.0.0.2:/tmp/
internal-gitlab.sql                                                                               100%  835KB  50.0MB/s   00:00

Импортиране на "internal-gitlab.sql" в PostgreSQL

Импортирайте базата данни в PostgreSQL:

sudo -u postgres psql -f /tmp/internal-gitlab.sql

Проверете дали базата данни вече е в PostgreSQL:

sudo -u postgres psql -l

Трябва да се появи следният ред:

gitlabhq_production | gitlab   | UTF8     | en_US.UTF-8 | en_US.UTF-8 |

Конфигуриране на GitLab

След импортиране на базата данни в PostgreSQL беше създаден потребител на gitlab. Трябва да промените паролата на този потребител.

Промяна на паролата:

sudo -u postgres psql -c "ALTER USER gitlab ENCRYPTED PASSWORD 'ПАРОЛЬ' VALID UNTIL 'infinity';"
Password for user postgres:
ALTER ROLE

След това на сървъра на GitLab, в конфигурационния файл /etc/gitlab/gitlab.rb, ще посочим всички данни на външния PostgreSQL.

Нека направим резервно копие на файла gitlab.rb:

cp /etc/gitlab/gitlab.rb /etc/gitlab/gitlab.rb.orig

Сега добавете тези редове в края на файла gitlab.rb:

# Отключить встроенный PostgreSQL.
postgresql['enable'] = false

# Данные для подключения к внешней базе. Указывайте свои.
gitlab_rails['db_adapter'] = 'postgresql'
gitlab_rails['db_encoding'] = 'utf8'
gitlab_rails['db_host'] = '10.0.0.2'
gitlab_rails['db_port'] = 5432
gitlab_rails['db_database'] = "gitlabhq_production"
gitlab_rails['db_username'] = 'gitlab'
gitlab_rails['db_password'] = '******'

Запазете файла /etc/gitlab/gitlab.rb и преконфигурирайте GitLab:

gitlab-ctl reconfigure && gitlab-ctl restart

Това е всичко :)

Голяма молба. Ако поставите минус, напишете причината в коментарите.

Източник: www.habr.com

Добавяне на нов коментар