通过 备份文件 恢复/迁移 GitLab
原文地址:http://www.cnblogs.com/straycats/p/7702271.html
部署:https://www.cnblogs.com/nethrd/p/9408254.html
升级:https://www.cnblogs.com/nethrd/p/9408290.html
本地备份:https://www.cnblogs.com/nethrd/p/9408330.html
远程备份:https://www.cnblogs.com/nethrd/p/9408362.html
通过之前的记录,已经掌握了gitlab的本地备份(http://www.cnblogs.com/straycats/p/7671204.html)和远程备份(http://www.cnblogs.com/straycats/p/7672692.html)。
但是获取备份文件不是我们的目的,最终是为了通过备份文件实现迁移或恢复gitlab。本篇就是记录如何通过备份文件在新的环境上去恢复/迁移gitlab。
一、环境准备
首先在新服务器(192.168.2.1)上搭建gitlab,部署过程可以参考http://www.cnblogs.com/straycats/p/7637373.html。
注意:通过备份文件恢复gitlab必须保证新的gitlab版本必须要和老的gitlab版本一致,否则会提示版本不匹配。
所以无非是两种思路,一种将老的gitlab先升级到你要的gitlab版本,再迁移备份;另一种将gitlab安装的版本和老gitlab一致,迁移完成后再进行升级。
我采取先保持一致后迁移,再进行升级。
二、配置新的gitlab
gitlab的配置文件(gitlab.rb)是不因备份恢复而恢复的,故要将老的gitlab的配置文件也取过来,否则就需要维护人员重新配置。
2.1 获取gitlab.rb
在新服务器上,使用scp命令将老服务器(192.168.1.1)的备份文件复制到/etc/gitlab/目录下。
scp root@192.168.1.1:/etc/gitlab/gitlab.rb /etc/gitlab/gitlab.rb
第一次连接时会询问是否要继续连接,输入yes,回车。
接着输入老服务器的root密码后,回车。
接着就会看到备份文件传输的信息。
2.2 修改external_url
如果新gitlab服务器部署之后ip不改回老的ip(示例为192.168.1.1),故需要修改gitlab.rb的external_url参数,因为页面上项目的http地址就是根据该参数拼接而成的。
以新gitlab服务器的ip为192.168.2.1为例,修改gitlab配置文件。
vim /etc/gitlab/gitlab.rb
修改external_url,wq保存。
external_url 'http://192.168.2.1'
2.3 重新配置gitlab
gitlab-ctl reconfigure
三、获取备份文件
在新服务器上,使用scp命令将老服务器(192.168.1.1)的备份文件(1508412719_2017_10_19_10.0.2_gitlab_backup.tar)复制到/var/opt/gitlab/backups/目录下。
scp root@192.168.1.1:/var/opt/gitlab/backups/1508412719_2017_10_19_10.0.2_gitlab_backup.tar /var/opt/gitlab/backups/
获取到/var/opt/gitlab/backups/目录下是因为我没有特别更换gitlab的备份目录,如果gitlab.rb有指定别的目录,根据实际情况自行修改。
第一次连接时会询问是否要继续连接,输入yes,回车。
接着输入老服务器的root密码后,回车。
接着就会看到备份文件传输的信息。
如果老服务器出现故障时,云端有备份文件可以从云端获取,比如云端192.168.1.2的/gitlab-backup目录下有备份文件,可以从那获取。
scp root@192.168.1.2:/gitlab-backup/1508412719_2017_10_19_10.0.2_gitlab_backup.tar /var/opt/gitlab/backups/
四、恢复/迁移gitlab数据
4.1 修改备份文件权限
将备份文件的权限改为777,否则恢复的时候会出现权限不够导致解压失败的问题。
chmod 777 /var/opt/gitlab/backups/1508412719_2017_10_19_10.0.2_gitlab_backup.tar
4.2 停止相关数据连接服务
gitlab-ctl stop unicorn gitlab-ctl stop sidekiq
4.3 恢复gitlab
使用“gitlab-rake gitlab:backup:restore BACKUP=备份文件编号”指令可以根据备份文件来恢复,因为示例中是使用1508412719_2017_10_19_10.0.2_gitlab_backup.tar来恢复,故备份文件编号为1508412719_2017_10_19_10.0.2。
gitlab-rake gitlab:backup:restore BACKUP=1508412719_2017_10_19_10.0.2
等待片刻后,由于新的gitlab还是处于初始状态,直接输入“yes”,回车。
然后就是等待恢复的结束。
到了下面的内容时,输入“yes”,回车。
4.4 启动gitlab
gitlab-ctl start
五、关于本地备份和远程备份
由于这两块是额外配置的,如果新环境中也要有这一套备份机制,自然需要维护人员手动配一次。
本地备份参考:http://www.cnblogs.com/straycats/p/7671204.html
远程备份参考:http://www.cnblogs.com/straycats/p/7672692.html
参考资料:
1. http://blog.csdn.net/ouyang_peng/article/details/77070977