本次安装在CentOS7下进行
1、安装yum
检查是否已经安装yum
yum --version
如果未安装
sudo yum install -y yum-utils
添加镜像源:
- 国外镜像源:
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
- 阿里镜像源:
yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/decker-ce.repo
2、安装docker
- 安装最新版本(默认):yum install docker-ce
- 安装指定版本:yum install docker-ce-20.10.9-3.el7
配置开机启动:
- 启动docker:systemctl start docker
- 配置开机启动:systemctl enable docker
- 查看docker版本:docker version
3、docker部署gitlab
拉取最新gitlab镜像
方式一:直接使用最新版本镜像
- docker pull gitlab/gitlab-ce:latest
方式二:使用指定版本镜像,这里使用了13.10.0版本 (教程使用的此方式)
- docker pull gitlab/gitlab-ce:13.10.0-ce.0
创建映射文件目录
# 映射配置文件夹
mkdir -p /home/gitlab/conf
# 映射日志文件夹
mkdir -p /home/gitlab/logs
# 映射数据文件夹
mkdir -p /home/gitlab/data
运行docker容器
最好不要使用80端口,使用了也没问题后面会教你更改
后面会改成 --publish 50055:50055 \
# 主机名、端口映射、目录映射、gitlab版本 需自行修改
sudo docker run --detach \
--hostname ip地址 \
--publish 50055:80 \
--name gitlab \
--restart always \
--volume /data/gitlab/conf:/etc/gitlab \
--volume /data/gitlab/logs:/var/log/gitlab \
--volume /data/gitlab/data:/var/opt/gitlab \
--shm-size 256m \
--privileged=true gitlab/gitlab-ce:13.10.0-ce.0
一劳永逸版
sudo docker run --detach \
--hostname ip地址 \
--publish 50055:50055 \
--name gitlab \
--restart always \
--volume /data/gitlab/conf:/etc/gitlab \
--volume /data/gitlab/logs:/var/log/gitlab \
--volume /data/gitlab/data:/var/opt/gitlab \
--shm-size 256m \
--privileged=true gitlab/gitlab-ce:13.10.0-ce.0
修改gitlab服务端口号:vim /etc/gitlab/gitlab.rb
external_url 'http://ip:50055'
使用命令进行更新配置:gitlab-ctl reconfigure
查看防火墙
查看开放的端口号
firewall-cmd --list-all
开放指定端口
sudo firewall-cmd --add-port=50055/tcp --permanent
重启防火墙(设置完一定要重启防火墙):
firewall-cmd --reload
现在外部就可以访问这些端口了
4、备份
注意这里gitlab的版本,后面恢复是要保证版本一致的
# 查看容器id
docker ps
# 进入容器 示例:docker exec -it -i 4c97d29eee9b /bin/bash
docker exec -it -i <这里是容器id> /bin/bash
# 执行备份命令
gitlab-rake gitlab:backup:create
备份文件可在 /data/gitlab/data/backups找到
5、恢复
要注意恢复版本要和备份版本保持一致
# 把第一台服务器备份的 xxx_gitlab_backup.tar 文件拷贝到新gitlab的/data/gitlab/data/backups目录中
# 进入容器 示例:docker exec -it -i 4c97d29eee9b /bin/bash
docker ps
docker exec -it -i <这里是容器id> /bin/bash
# 修改权限
chmod 777 /var/opt/gitlab/backups/1682571554_2023_04_27_13.5.4_gitlab_backup.tar
chown -R git:git /var/opt/gitlab/backups/1682571554_2023_04_27_13.5.4_gitlab_backup.tar
# 恢复备份文件前,先停止容器内相关数据连接服务
gitlab-ctl stop puma
gitlab-ctl stop unicorn
gitlab-ctl stop sidekiq
# 最好修改下数据权限,不然恢复容易报错
# 修改postgresql配置
vi /var/opt/gitlab/postgresql/data/postgresql.conf
# 如下修改:
listen_addresses = '*'
# 修改pg_hba配置
vi /var/opt/gitlab/postgresql/data/pg_hba.conf
# 最后添加:
local all all trust
host all all 127.0.0.1/32 trust
# 重启gitlab服务
gitlab-ctl restart
# 修改gitlab账号为超级用户
su - gitlab-psql
/opt/gitlab/embedded/bin/psql -h 127.0.0.1 gitlabhq_production
ALTER USER gitlab WITH SUPERUSER;
\q
exit
# 恢复备份文件前,先停止容器内相关数据连接服务
gitlab-ctl stop puma
gitlab-ctl stop unicorn
gitlab-ctl stop sidekiq
# 恢复备份, 后面的数字是 1682571554_2023_04_27_13.5.4_gitlab_backup.tar文件的前面一部分
gitlab-rake gitlab:backup:restore BACKUP=1682571554_2023_04_27_13.5.4
# 重启服务
gitlab-ctl restart
# 拷贝配置文件
cp gitlab-secrets.json /data/gitlab/conf/
cp gitlab.rb /data/gitlab/conf/
# 重启服务
gitlab-ctl restart
修改服务端口号
由于使用的80端口映射,导致gitlab克隆没有端口号,拉不了代码。
解决方法
1、修改服务的端口号
修改gitlab服务端口号:vim /etc/gitlab/gitlab.rb
external_url 'http://ip:50055'
使用命令进行更新配置:gitlab-ctl reconfigure
2、进入gitlab容器
修改配置文件gitlab.yml,修改host 与上面.rb文件修改的一致
cd /opt/gitlab/embedded/service/gitlab-rails/config
重启服务
gitlab-ctl restart
3、修改docker容器映射端口,也就是上面docker run 使用的80端口
修改 hostconfig.json 文件,找到如下配置,可以添加想要开放的端口
"PortBindings":{
"80/tcp":[
{
"HostIp":"",
"HostPort":"80"
}
],
"8088/tcp":[
{
"HostIp":"",
"HostPort":"8088"
}
]
}
修改 config.v2.json 文件,找到如下配置,可以添加想要开放的端口
"ExposedPorts":{
"80/tcp":{
},
"8088/tcp":{
}
}
注:并不需要修改Ports,只有在你没有stop容器时,Ports才会有值,如果关闭了容器,就是null。当然如果你修改了也无所谓,因为重启容器后,就会被刷新。
重启docker和容器即可
重启docker命令如下:
systemctl start docker