docker Gitlab和Jenkins的迁移

239 阅读3分钟
原文链接: mp.weixin.qq.com

我觉得自己迁移的方法挺 low 的,但时间紧迫,而且公司在 gitlab 也没账号,只好通过很原始的文件 cvs 操作。还是有点点小坑的,记录下。

一开始我很傻的以为,只要把 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

    进入容器身体,哦不,内部;

sh docker exec -it gitlab /bin/bash

    紧接着,趁胜追击,打出备份命令;

sh gitlab-rake gitlab:backup:create

    这时在 ` /var/opt/gitlab/backup ` 目录会有备份文件,文件名类似 ` 1559814146_2019_06_06_11.6.3_gitlab_backup.tar `;

    ![](https://p1-jj.byteimg.com/tos-cn-i-t2oaga2asx/gold-user-assets/2019/6/11/16b45e388bc3894a~tplv-t2oaga2asx-image.image)

    事情做完,不再纠缠,把这个备份包用scp传到新的服务器上。

sh scp 15598141462019060611.6.3gitlabbackup.tar administrator@172.16.30.151:/home/administrator

                        

    接着用 docker把当前容器也备份

sh docker export gitlab>gitlab_c.tar

    同样的,scp到新的服务器

sh scp gitlab_c.tar administrator@172.16.30.151:/home/administrator

    登录到新的服务器,导入容器

sh docker import gitlab_c.tar gitlab:1.0

    启动,手动导入的镜像启动的时候要把执行命令 ` /assets/wrapper ` 也带上,执行命令用 ` docker inspect gitlab` 查看,短的 ` docker ps ` 直接看得到。

    ![](https://p1-jj.byteimg.com/tos-cn-i-t2oaga2asx/gold-user-assets/2019/6/12/16b49337f784e255~tplv-t2oaga2asx-image.image)

sh 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 备份包

sh gitlab-rake gitlab:backup:restore BACKUP=15598141462019060611.6.3 ```

重启容器 docker restart gitlab即可,Gitlab备份恢复需要版本号一致,直接备份容器不会出现问题。

Jenkins

Jenkins 相对 Gitlab 好点的地方是所有的数据都在 jenkins_home 目录下,而且只有一个要求——该目录的所有者 uid 为1000。

TMD 我用 chown 改了半天发现文件夹所有者始终为 administrator,最后发现用户 administrator 的uid就是 1000 。。。

直接同 Gitlab 备份容器和 data 再 scp 过去解压就好了。

关键是里面脚本好多要改的啊~~~

脚本内容详见怎么用Jenkins配置分布式环境的安全发布?


欢迎关注微信公众号,提供感悟和技术类原创文章。微信搜索小兵张健或扫描以下二维码。