GitLab を外部の PostgreSQL に接続する
PostgreSQL サーバを外部に立てて GitLab の DB として運用します。
PostgreSQL サーバ側の設定
postgres ユーザになる
sudo su - postgres
postgreSQL に接続
psql
gitlab ユーザの作成
CREATE USER gitlab with PASSWORD 'gitlab_secret';
ユーザが作成されていることを確認
SELECT * FROM pg_user;
gitlabhq_production データベース作成
CREATE DATABASE gitlabhq_production OWNER gitlab;
スーパーユーザ権限付与
ALTER ROLE gitlab WITH SUPERUSER;
SELECT * FROM pg_user;でusersuperがtになっていることを確認
pg_hba.conf を vim などでを編集
find / -name pg_hba.conf 2> /dev/null
ファイルの末尾に以下を追記
host all all 192.168.144.0/24 trust
サービスを再起動して変更を適用
sudo service postgresql restart
GitLab サーバ側の設定
以下の設定を追記します。パッケージ版であればgitlab.rbファイルを編集してください。コンテナ版であればdocker-compose.yamlのservices.gitlab.environment.GITLAB_OMNIBUS_CONFIGに以下を追記します。
# Disable the built-in Postgres
postgresql['enable'] = false
# Fill in the connection details for database.yaml
gitlab_rails['db_adapter'] = 'postgresql'
gitlab_rails['db_encoding'] = 'utf8'
gitlab_rails['db_username'] = 'gitlab'
gitlab_rails['db_password'] = 'gitlab_secret'
gitlab_rails['db_host'] = '${PostgreSQLのIPアドレス}'
gitlab_rails['db_port'] = 5432
あとはいつも通りdocker-compose up -dで起動すれば OK です。