码迷,mamicode.com
首页 > 其他好文 > 详细

Gitlab数据迁移

时间:2015-12-15 19:35:23      阅读:5566      评论:0      收藏:0      [点我收藏+]

标签:gitlab数据迁移

迁移环境准备:

    Gitlab数据迁移需在同版本之间进行。因为不同版本的gitlab之间,数据库的库表结构与程序的实现方式是有差异的。若需从服务器A把gitlab的数据迁移至服务器B,则服务器B需部署与服务器A同样版本的gitlab方可。

迁移实现方式:

    可以使用gitlab备份与恢复的命令,实现数据的迁移。

    备份:

bundle exec rake gitlab:backup:create RAILS_ENV=production

    该备份命令会备份本地gitlab的所有项目的仓库以及mysql数据。

    恢复:

bundle exec rake gitlab:backup:restore RAILS_ENV=production BACKUP=Timestamp

 该恢复命令会导入备份中的mysql数据和项目仓库目录,并可以根据需要,从mysql库中的数据中重构~/.ssh/authorized_keys身份验证文件。


迁移操作:

    服务器A:

#su - git
$cd gitlab
$ bundle exec rake gitlab:backup:create RAILS_ENV=production

    若运行无错误,备份成功后,在备份目录(默认为/home/git/gitlab/tmp/backups)下会生成一个备份tar包,里面包含了gitlab项目仓库以及mysql导出数据。

   文件格式如:1449731757_gitlab_backup.tar,其中“1449731757”为备份文件的时间戳。

   上传备份文件到服务器B的备份目录。


    服务器B:

#chown git.git /home/git/gitlab/tmp/backups/1449731757_gitlab_backup.tar
#su - git
$cd gitlab
$ bundle exec rake gitlab:backup:restore RAILS_ENV=production BACKUP=1449731757

    注意这里的“BACKUP=1449731757”,这里需填写想恢复文件时间戳。

若运行无误,则数据迁移完成。


 注:gitlab的默认备份目录,可以在/home/git/gitlab/config/gitlab.yml中修改:

$vi /home/git/gitlab/config/gitlab.yml
    backup:
    path: "tmp/backups"



本文出自 “linux运维” 博客,请务必保留此出处http://icenycmh.blog.51cto.com/4077647/1723296

Gitlab数据迁移

标签:gitlab数据迁移

原文地址:http://icenycmh.blog.51cto.com/4077647/1723296

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!