zoukankan      html  css  js  c++  java
  • Gitlab日常维护(三)之Gitlab的备份、迁移、升级

    一、Gitlab的备份

    使用Gitlab一键安装包安装Gitlab非常简单, 同样的备份恢复与迁移也非常简单. 使用一条命令即可创建完整的Gitlab备份

    [root@gitlab ~]# gitlab-rake gitlab:backup:create          
    //比如使用以上命令会在/var/opt/gitlab/backups目录下创建一个名称类似为1481598919_gitlab_backup.tar的压缩包, 这个压缩包就是Gitlab整个的完整部分,
    其中开头的1481598919是备份创建的日期。
     
    /etc/gitlab/gitlab.rb 配置文件须备份
    /var/opt/gitlab/nginx/conf nginx配置文件
    /etc/postfix/main.cfpostfix 邮件配置备份
    

    1、Gitlab备份目录
    可以通过/etc/gitlab/gitlab.rb配置文件来修改默认存放备份文件的目录

    [root@code-server ~]# vim /etc/gitlab/gitlab.rb
    gitlab_rails['manage_backup_path'] = true
    gitlab_rails['backup_path'] = "/data/gitlab/backups"    //gitlab备份目录
    gitlab_rails['backup_archive_permissions'] = 0644       //生成的备份文件权限
    gitlab_rails['backup_keep_time'] = 7776000              //备份保留天数为3个月(即90天,这里是7776000秒)
     
    [root@code-server ~]# mkdir -p /data/gitlab/backups
    [root@code-server ~]# chown -R git.git /data/gitlab/backups
    [root@code-server ~]# chmod -R 777 /data/gitlab/backups
      
    如上设置了gitlab备份目录路径为/data/gitlab/backups,最后使用下面命令重载gitlab配置文件,是上述修改生效!
    root@code-server ~]# gitlab-ctl reconfigure 
    gitlab_rails['backup_path'] = "/var/opt/gitlab/backups"
    /var/opt/gitlab/backups修改为你想存放备份的目录即可, 修改完成之后使用gitlab-ctl reconfigure命令重载配置文件即可.
    

    2、Gitlab自动备份

    编写备份脚本,结合crontab实施自动定时备份,比如每天0点、6点、12点、18点各备份一次
    [root@code-server backups]# pwd
    /data/gitlab/backups
    [root@code-server backups]# vim gitlab_backup.sh
    #!/bin/bash
    /usr/bin/gitlab-rake gitlab:backup:create CRON=1
     
    注意:环境变量CRON=1的作用是如果没有任何错误发生时, 抑制备份脚本的所有进度输出
     
    [root@code-server backups]# crontab -l
    0 0,6,12,18 * * * /bin/bash -x /data/gitlab/backups/gitlab_backup.sh > /dev/null 2>&1

    现在我们公司实现每天凌晨2点进行一次自动备份:通过crontab使用备份命令实现

    0 2 * * * /opt/gitlab/bin/gitlab-rake gitlab:backup:create  

    二、Gitlab恢复

    GItlab只能还原到与备份文件相同的gitlab版本。
    假设在上面gitlab备份之前创建了test项目,然后不小心误删了test项目,现在就进行gitlab恢复操作:
      
    1)停止相关数据连接服务
    [root@code-server backups]# gitlab-ctl stop unicorn
    ok: down: unicorn: 0s, normally up
    [root@code-server backups]# gitlab-ctl stop sidekiq
    ok: down: sidekiq: 1s, normally up
    [root@code-server backups]# gitlab-ctl status
    run: gitaly: (pid 98087) 1883s; run: log: (pid 194202) 163003s
    run: gitlab-monitor: (pid 98101) 1883s; run: log: (pid 194363) 163002s
    run: gitlab-workhorse: (pid 98104) 1882s; run: log: (pid 194362) 163002s
    run: logrotate: (pid 98117) 1882s; run: log: (pid 5793) 160832s
    run: nginx: (pid 98123) 1881s; run: log: (pid 194359) 163002s
    run: node-exporter: (pid 98167) 1881s; run: log: (pid 194360) 163002s
    run: postgres-exporter: (pid 98173) 1881s; run: log: (pid 194204) 163003s
    run: postgresql: (pid 98179) 1880s; run: log: (pid 194365) 163002s
    run: prometheus: (pid 98187) 1880s; run: log: (pid 194364) 163002s
    run: redis: (pid 98230) 1879s; run: log: (pid 194358) 163002s
    run: redis-exporter: (pid 98234) 1879s; run: log: (pid 194208) 163003s
    down: sidekiq: 8s, normally up; run: log: (pid 194437) 163001s
    down: unicorn: 21s, normally up; run: log: (pid 194443) 163001s
      
    2)现在通过之前的备份文件进行恢复(必须要备份文件放到备份路径下,这里备份路径我自定义的/data/gitlab/backups,默认的是/var/opt/gitlab/backups)
    [root@code-server backups]# pwd
    /data/gitlab/backups
    [root@code-server backups]# ll
    total 244
    -rw-r--r-- 1 git git 245760 Nov 12 15:33 1510472027_2017_11_12_9.4.5_gitlab_backup.tar
      
    Gitlab的恢复操作会先将当前所有的数据清空,然后再根据备份数据进行恢复
    [root@code-server backups]# gitlab-rake gitlab:backup:restore BACKUP=1510472027_2017_11_12_9.4.5
    Unpacking backup ... done
    Before restoring the database we recommend removing all existing
    tables to avoid future upgrade problems. Be aware that if you have
    custom tables in the GitLab database these tables and all data will be
    removed.
      
    Do you want to continue (yes/no)?
    ........
    ALTER TABLE
    ALTER TABLE
    ALTER TABLE
    ALTER TABLE
    WARNING:  no privileges were granted for "public"
    GRANT
    [DONE]
    done
    Restoring repositories ...
     * treesign/treesign ... [DONE]
     * gateway/gateway ... [DONE]
     * treesign/treesign-doc ... [DONE]
     * qwsign/qwsign ... [DONE]
     * qwsign/qwsign-doc ... [DONE]
     * test/test ... [DONE]
    Put GitLab hooks in repositories dirs [DONE]
    done
    Restoring uploads ...
    done
    Restoring builds ...
    done
    Restoring artifacts ...
    done
    Restoring pages ...
    done
    Restoring lfs objects ...
    done
    This will rebuild an authorized_keys file.
    You will lose any data stored in authorized_keys file.
    Do you want to continue (yes/no)? yes
      
      
    Deleting tmp directories ... done
    done
    done
    done
    done
    done
    done
    done
    [root@code-server backups]#
      
    最后再次启动Gitlab
    [root@code-server backups]# gitlab-ctl start
    ok: run: gitaly: (pid 98087) 2138s
    ok: run: gitlab-monitor: (pid 98101) 2138s
    ok: run: gitlab-workhorse: (pid 98104) 2137s
    ok: run: logrotate: (pid 98117) 2137s
    ok: run: nginx: (pid 98123) 2136s
    ok: run: node-exporter: (pid 98167) 2136s
    ok: run: postgres-exporter: (pid 98173) 2136s
    ok: run: postgresql: (pid 98179) 2135s
    ok: run: prometheus: (pid 98187) 2135s
    ok: run: redis: (pid 98230) 2134s
    ok: run: redis-exporter: (pid 98234) 2134s
    ok: run: sidekiq: (pid 104494) 0s
    ok: run: unicorn: (pid 104497) 1s
    [root@code-server backups]# gitlab-ctl status
    run: gitaly: (pid 98087) 2142s; run: log: (pid 194202) 163262s
    run: gitlab-monitor: (pid 98101) 2142s; run: log: (pid 194363) 163261s
    run: gitlab-workhorse: (pid 98104) 2141s; run: log: (pid 194362) 163261s
    run: logrotate: (pid 98117) 2141s; run: log: (pid 5793) 161091s
    run: nginx: (pid 98123) 2140s; run: log: (pid 194359) 163261s
    run: node-exporter: (pid 98167) 2140s; run: log: (pid 194360) 163261s
    run: postgres-exporter: (pid 98173) 2140s; run: log: (pid 194204) 163262s
    run: postgresql: (pid 98179) 2139s; run: log: (pid 194365) 163261s
    run: prometheus: (pid 98187) 2139s; run: log: (pid 194364) 163261s
    run: redis: (pid 98230) 2138s; run: log: (pid 194358) 163261s
    run: redis-exporter: (pid 98234) 2138s; run: log: (pid 194208) 163262s
    run: sidekiq: (pid 104494) 4s; run: log: (pid 194437) 163260s
    run: unicorn: (pid 104497) 4s; run: log: (pid 194443) 163260s
     
    恢复命令完成后,可以check检查一下恢复情况
    [root@code-server backups]# gitlab-rake gitlab:check SANITIZE=true
    Checking GitLab Shell ...
     
    GitLab Shell version >= 5.3.1 ? ... OK (5.3.1)
    Repo base directory exists?
    default... yes
    Repo storage directories are symlinks?
    default... no
    Repo paths owned by git:root, or git:git?
    default... yes
    Repo paths access is drwxrws---?
    default... yes
    hooks directories in repos are links: ...
    5/1 ... ok
    6/2 ... ok
    5/3 ... repository is empty
    12/4 ... ok
    12/5 ... ok
    Running /opt/gitlab/embedded/service/gitlab-shell/bin/check
    Check GitLab API access: OK
    Access to /var/opt/gitlab/.ssh/authorized_keys: OK
    Send ping to redis server: OK
    gitlab-shell self-check successful
     
    Checking GitLab Shell ... Finished
     
    Checking Sidekiq ...
     
    Running? ... yes
    Number of Sidekiq processes ... 1
     
    Checking Sidekiq ... Finished
     
    Checking Reply by email ...
     
    Reply by email is disabled in config/gitlab.yml
     
    Checking Reply by email ... Finished
     
    Checking LDAP ...
     
    LDAP is disabled in config/gitlab.yml
     
    Checking LDAP ... Finished
     
    Checking GitLab ...
     
    Git configured correctly? ... yes
    Database config exists? ... yes
    All migrations up? ... yes
    Database contains orphaned GroupMembers? ... no
    GitLab config exists? ... yes
    GitLab config up to date? ... yes
    Log directory writable? ... yes
    Tmp directory writable? ... yes
    Uploads directory exists? ... yes
    Uploads directory has correct permissions? ... yes
    Uploads directory tmp has correct permissions? ... yes
    Init script exists? ... skipped (omnibus-gitlab has no init script)
    Init script up-to-date? ... skipped (omnibus-gitlab has no init script)
    Projects have namespace: ...
    5/1 ... yes
    6/2 ... yes
    5/3 ... yes
    12/4 ... yes
    12/5 ... yes
    Redis version >= 2.8.0? ... yes
    Ruby version >= 2.3.3 ? ... yes (2.3.3)
    Git version >= 2.7.3 ? ... yes (2.13.4)
    Active users: ... 11
     
    Checking GitLab ... Finished
      
    然后稍等一会(如果启动gitlab后,访问出现500,这是因为redis等程序还没完全启动,等一会儿访问就ok了),再次登录Gitlab,就会发现之前误删除的test项目已经恢复了!
      
    另外:Gitlab迁移与恢复一样,但是要求两个GitLab版本号一致

    三、Gitlab迁移

    注意:新服务器的gitlab版本与旧的服务器相同。  

    迁移如同备份与恢复的步骤一样, 只需要将老服务器/var/opt/gitlab/backups目录下的备份文件拷贝到新服务器上的/var/opt/gitlab/backups即可(如果你没修改过默认备份目录的话).

    但是需要注意的是:
    新服务器上的Gitlab的版本必须与创建备份时的Gitlab版本号相同. 比如新服务器安装的是最新的7.60版本的Gitlab, 那么迁移之前, 最好将老服务器的Gitlab 升级为7.60在进行备份.

    /etc/gitlab/gitlab.rb                  这个gitlab配置文件须迁移,迁移后需要调整数据存放目录
    /var/opt/gitlab/nginx/conf        这个nginx配置文件目录须迁移
    
    /etc/gitlab/gitlab-secrets.json       #复制新服务器相同的目录下
    /etc/ssh/*key*                               #复制到新服务器相同目录下,解决ssh key认证不成功问题
    
    [root@gitlab ~]# gitlab-ctl stop unicorn
    [root@gitlab ~]# gitlab-ctl stop sidekiq
    [root@gitlab ~]# chmod 777 /var/opt/gitlab/backups/1481598919_gitlab_backup.tar  # 或 chown git:git /var/opt/gitlab/backups/1481598919_gitlab_backup.tar
    [root@gitlab ~]# gitlab-rake gitlab:backup:restore BACKUP=1481598919  

    四、Gitlab升级

    1.关闭gitlab服务
    # gitlab-ctl stop unicorn
    # gitlab-ctl stop sidekiq
    # gitlab-ctl stop nginx
     
    2.备份gitlab
    # gitlab-rake gitlab:backup:create
     
    3.下载gitlab的RPM包并进行升级
    # curl -s https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.rpm.sh | sudo bash
    # yum update gitlab-ce
     
    或者直接安装高版本
    #yum install gitlab-ce-12.1.12-ce.0.el7.x86_64
     
    或者上官网下载最新版本 gitlab对应软件包                                    
    gitlab官网地址: https://packages.gitlab.com/gitlab/gitlab-ce/packages/el/7/gitlab-ce-12.1.12-ce.0.el7.x86_64.rpm
    使用:
    # rpm -Uvh gitlab-ce-12.1.12-ce.0.el7.x86_64
     
    如果报错.
    Error executing action `run` on resource 'ruby_block[directory resource: /var/opt/gitlab/git-data/repositories]'
     
    解决方法:
    sudo chmod 2770 /var/opt/gitlab/git-data/repositories
     
    4.启动并查看gitlab版本信息
    # gitlab-ctl reconfigure
    # gitlab-ctl restart
    # head -1 /opt/gitlab/version-manifest.txt
    

    -----------------------------------------------------------书山有路勤为径,学海无涯苦作舟-------------------------------------------------------------   

  • 相关阅读:
    批量修改文件的编码格式至UTF-8
    springboot搭建
    Redit集群搭建-Sentinel模式搭建
    Java并发编程:深入剖析ThreadLocal
    Hibernate常见问题 No row with the given identifier exists问题的解决办法及解决
    vector删除元素与清除内存空洞
    BZOJ 1003 [ZJOI2006]物流运输trans SPFA+DP
    Mybatis+Oracle批处理
    【日常学习】【线性DP】codevs1044 拦截导弹题解
    hdu5353 Average
  • 原文地址:https://www.cnblogs.com/easonscx/p/12615981.html
Copyright © 2011-2022 走看看