一开始我很傻的以为,只要把 data 文件 copy 过去就可以了,用 scp 搞了半天没搞好,文件权限、所有者全乱了,真的是太傻太天真。后来查了下资料换了思路,分别备份容器和数据,再 scp 慢慢磨合。
Gitlab
Gitlab的data即使tar后用scp传过在再解压也不能直接使用,会报 postgresql 文件的 permission denied 。
对比发现docker的Gitlab会在创建的时候新建 postgresql 用户,但每次用户名都不一样,导致此问题。
尝试将 date 权限 chmod -R 777 未能解决问题。采用 Gitlab 自带的备份恢复解决问题。
参考自Docker容器迁移 ---- 导入和导出容器 Gitlab如何进行备份恢复与迁移?
Gitlab内备份
Gitlab容器创建命令
docker run -d \
--privileged=true \
-p 444:443 -p 4000:80 -p 23:22 \
--name gitlab \
--restart always \
-v /storage/data/gitlab/config:/etc/gitlab \
-v /storage/data/gitlab/logs:/var/log/gitlab \
-v /storage/data/gitlab/data:/var/opt/gitlab \
gitlab/gitlab-ce:latest
复制代码
进入容器身体,哦不,内部;
docker exec -it gitlab /bin/bash
复制代码
紧接着,趁胜追击,打出备份命令;
gitlab-rake gitlab:backup:create
复制代码
这时在 /var/opt/gitlab/backup
目录会有备份文件,文件名类似 1559814146_2019_06_06_11.6.3_gitlab_backup.tar
;
事情做完,不再纠缠,把这个备份包用scp传到新的服务器上。
scp 1559814146_2019_06_06_11.6.3_gitlab_backup.tar administrator@172.16.30.151:/home/administrator
复制代码
接着用docker把当前容器也备份
docker export gitlab>gitlab_c.tar
复制代码
同样的,scp到新的服务器
scp gitlab_c.tar administrator@172.16.30.151:/home/administrator
复制代码
登录到新的服务器,导入容器
docker import gitlab_c.tar gitlab:1.0
复制代码
启动,手动导入的镜像启动的时候要把执行命令 /assets/wrapper
也带上,执行命令用 docker inspect gitlab
查看,短的 docker ps
直接看得到。
docker run -d \
--privileged=true \
-p 444:443 -p 4000:80 -p 23:22 \
--name gitlab \
--restart always \
-v /storage/data/gitlab/config:/etc/gitlab \
-v /storage/data/gitlab/logs:/var/log/gitlab \
-v /storage/data/gitlab/data:/var/opt/gitlab \
gitlab:1.0 \
/assets/wrapper
复制代码
进入容器内部,导入 Gitlab 备份包
gitlab-rake gitlab:backup:restore BACKUP=1559814146_2019_06_06_11.6.3
复制代码
重启容器docker restart gitlab
即可,Gitlab备份恢复需要版本号一致,直接备份容器不会出现问题。
Jenkins
Jenkins 相对 Gitlab 好点的地方是所有的数据都在 jenkins_home 目录下,而且只有一个要求——该目录的所有者 uid 为1000。
TMD 我用 chown 改了半天发现文件夹所有者始终为 administrator,最后发现用户 administrator 的uid就是 1000 。。。
直接同 Gitlab 备份容器和 data 再 scp 过去解压就好了。
关键是里面脚本好多要改的啊~~~
脚本内容详见怎么用Jenkins配置分布式环境的安全发布?