Gitlab数据迁移需在同版本之间进行。因为不同版本的gitlab之间,数据库的库表结构与程序的实现方式是有差异的。若需从服务器A把gitlab的数据迁移至服务器B,则服务器B需部署与服务器A同样版本的gitlab方可。
可以使用gitlab备份与恢复的命令,实现数据的迁移。
备份:
1
<code>bundle </code><code>exec</code> <code>rake gitlab:backup:create RAILS_ENV=production</code>
该备份命令会备份本地gitlab的所有项目的仓库以及mysql数据。
恢复:
<code>bundle </code><code>exec</code> <code>rake gitlab:backup:restore RAILS_ENV=production BACKUP=Timestamp</code>
该恢复命令会导入备份中的mysql数据和项目仓库目录,并可以根据需要,从mysql库中的数据中重构~/.ssh/authorized_keys身份验证文件。
服务器A:
2
3
<code>#su - git</code>
<code>$</code><code>cd</code> <code>gitlab</code>
<code>$ bundle </code><code>exec</code> <code>rake gitlab:backup:create RAILS_ENV=production</code>
若运行无错误,备份成功后,在备份目录(默认为/home/git/gitlab/tmp/backups)下会生成一个备份tar包,里面包含了gitlab项目仓库以及mysql导出数据。
文件格式如:1449731757_gitlab_backup.tar,其中“1449731757”为备份文件的时间戳。
上传备份文件到服务器B的备份目录。
服务器B:
4
<code>#chown git.git /home/git/gitlab/tmp/backups/1449731757_gitlab_backup.tar</code>
<code>$ bundle </code><code>exec</code> <code>rake gitlab:backup:restore RAILS_ENV=production BACKUP=1449731757</code>
注意这里的“BACKUP=1449731757”,这里需填写想恢复文件时间戳。
若运行无误,则数据迁移完成。
注:gitlab的默认备份目录,可以在/home/git/gitlab/config/gitlab.yml中修改:
<code>$</code><code>vi</code> <code>/home/git/gitlab/config/gitlab</code><code>.yml</code>
<code> </code><code>backup:</code>
<code> </code><code>path: </code><code>"tmp/backups"</code>
<code></code>
本文转自 icenycmh 51CTO博客,原文链接:http://blog.51cto.com/icenycmh/1723296,如需转载请自行联系原作者