gitlab服务器迁移(亲测有效)

描述:最近公司迁移gitlab,我没有迁移过,经过网上查找资料最终完成迁移,途中也遇到挺多坑和两个问题,希望能帮到你。

新服务器安装gitlab

注意:新服务器gitlab版本也需要和旧版本一致。

首先查看原Gitlab版本

复制代码
cat /opt/gitlab/embedded/service/gitlab-rails/VERSION

我的系统是unbuntu,系统不一致安装方法可能不大一直,需注意一下。

安装

更新系统包

复制代码
sudo apt-get update
sudo apt-get upgrade

安装依赖包

复制代码
sudo apt-get install -y curl openssh-server ca-certificates

添加 GitLab 仓库

复制代码
curl -sS https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.deb.sh | sudo bash

安装 GitLab 13.6.3

(注意:我的版本是13.6.3)

复制代码
udo EXTERNAL_URL="http://gitlab.example.com" apt-get install gitlab-ce=13.6.3-ce.0

请将 http://gitlab.example.com 替换为你的 GitLab 域名或ip+端口。

出现以下提示,表示安装成功

配置

进入配置文件

复制代码
sudo vim /etc/gitlab/gitlab.rb

配置对外IP和默认端口(大概第33行)

保存退出使配置生效

复制代码
gitlab-ctl reconfigure

备份原gitlab数据

备份配置文件

先备份一下一下两个文件

复制代码
/etc/gitlab/gitlab.rc
/etc/gitlab/gitlab-secrets.json

/etc/gitlab/gitlab-secrets.json文件,此文件中包含数据库加密密钥,CI/CD变量以及双因子认证等变量信息,如果在GitLab中使用到此部分内容,必须进行此文件的手动恢复。

数据备份

旧服务器执行进行数据备份

复制代码
gitlab-rake gitlab:backup:create

备份地址在 /var/opt/gitlab/backups/下

复制代码
cd /var/opt/gitlab/backups/
ll

下载并传输到新服务器的/var/opt/gitlab/backups/下,注意权限问题(下载前和上传后最好都将权限赋值为777)

linux 复制代码
sudo chmod 777 1716965063_2024_05_29_13.6.3_gitlab_backup.tar

还原

停止unicorn和sidekiq服务,puma服务

复制代码
gitlab-ctl stop nginx && gitlab-ctl  stop puma && gitlab-ctl  stop unicorn && gitlab-ctl stop sidekiq

应用备份数据 中途输入两个yes

注意BACKUP=打包的编号

复制代码
gitlab-rake gitlab:backup:restore BACKUP=1716978170_2024_05_29_13.6.3


替换gitlab-secrets.json文件

将旧服务器/etc/gitlab/gitlab-secrets.json替换新服务器/etc/gitlab/gitlab-secrets.json,注意先提前备份一下新服务器该文件,以免有问题还原。

重启gitlab服务

复制代码
gitlab-ctl restart

问题

在还原过程中遇到两个问题,下面列出问题以及解决方法

问题1

linux 复制代码
PG::ConnectionBad: could not connect to server: No such file or directory
Is the server running locally and accepting
connections on Unix domain socket "/var/opt/gitlab/postgresql/.s.PGSQL.5432"?
/opt/gitlab/embedded/service/gitlab-rails/lib/tasks/gitlab/db.rake:49:in `block (3 levels) in <top (required)>'
/opt/gitlab/embedded/bin/bundle:23:in `load'
/opt/gitlab/embedded/bin/bundle:23:in `<main>'
Tasks: TOP => gitlab:db:configure
(See full trace by running task with --trace)

解决方法:

1、按住CTRL+C强制结束

2、先停止 gitlab ,命令: sudo gitlab-ctl stop

3、执行命令: sudo chmod 755 /var/opt/gitlab/postgresql

4、执行命令:sudo systemctl restart gitlab-runsvdir

5、再次配置:sudo gitlab-ctl reconfigure

6、启动即可:sudo gitlab-ctl restart

问题2

linxu 复制代码
Restoring PostgreSQL database gitlabhq_production ... ERROR:  must be owner of extension pg_trgm
ERROR:  must be owner of extension btree_gist
ERROR:  must be owner of extension btree_gist
ERROR:  must be owner of extension pg_trgm

解决办法:

1、修改postgresql相关配置

linxu 复制代码
# 修改以下配置文件,修改端口监听地址,默认监控localhost,* 代表all
$ vim /var/opt/gitlab/postgresql/data/postgresql.conf
 
listen_addresses = '*'
# 以下配置文件新增以下两行
$ vim /var/opt/gitlab/postgresql/data/pg_hba.conf
 
local   all         all                               trust
host    all         all                               127.0.0.1/32 trust

2、重启gitlab服务

linxu 复制代码
gitlab-ctl restart

3、修改数据

linxu 复制代码
$ su - gitlab-psql
 
$ /opt/gitlab/embedded/bin/psql -h 127.0.0.1 gitlabhq_production
 
gitlabhq_production=# ALTER USER gitlab WITH SUPERUSER;
 
ALTER ROLE
 
gitlabhq_production=# \q
 
$ exit

參考

Gitlab旧服务器迁移新服务器
Ubuntu安装gitlab教程
GitLab 报错 ConnectionBad: could not connect to server: No such...
gitlab备份数据 gitlab项目备份
gitlab安装以及数据迁移

相关推荐
camellias_18 小时前
ubuntu(二)ubuntu18.04安装mysql8
linux·ubuntu·adb
藤谷性能18 小时前
Ubuntu 22.04:安装串口调试助手CoolTerm
linux·运维·ubuntu·串口·coolterm
丶伯爵式18 小时前
Ubuntu 新装后常用设置
linux·运维·ubuntu
吴烦恼的博客19 小时前
WSL迁移指南
ubuntu·wsl·系统移植
问简20 小时前
ubuntu 输入法优化
linux·运维·ubuntu
勤自省20 小时前
Windows 文件无法粘贴到 Linux(Ubuntu)系统的解决方案
linux·windows·ubuntu
博主花神1 天前
【TypeScript】梳理
javascript·ubuntu·typescript
有理想的打工人1 天前
gitlab的参数设置与团队管理
gitlab
想唱rap1 天前
计算机网络基础
linux·计算机网络·mysql·ubuntu·bash
程序员老邢1 天前
【技术底稿 10】16G Ubuntu 服务器手动部署 Ollama 0.20.4 全流程(避坑 HTTP2 错误)
服务器·ubuntu·ai·语言模型·devops