Gitlab之间进行同步备份
csdh11 2025-01-13 12:04 2 浏览
目前,我们公司有两个研发团队,分别在北京和武汉,考虑到访问速度的问题,原有武汉的研发环境在近端部署。也就是北京和武汉分别有两套独立的研发管理环境,虽然这解决了近端访问速度的问题,但是管理上较为分散,比如研发环境备份和恢复就是最重要的问题之一。最近,处于对安全性和合规性的考虑,希望将北京和武汉的源代码,统一的集中备份,防止公司资产流失。
Gitlab同步备份需求分析
由于历史原因,北京团队使用Gerrit进行代码审核和管理的工具,但是对于很多开发人员来说,入门比较陡峭,需要记忆很多git命令,所以考虑团队扩展性的需要,将Gerrit环境逐步切换至Gitlab中,而武汉团队则是直接选择了Gitlab进行代码管理。
在选择目标侧环境时,原本想使用阿里云效和腾讯的Coding环境进行备份,以我们目前体量来看,是完全免费的。但是考虑到随着公司增长,后期可能会产生成本,所以决定利用现有的K8S生产环境部署一套Gitlab,用于代码备份。
所以本次要解决的问题就是将两个团队Gitlab环境下的所有项目定期备份至远程的Gitlab中。在最初期的方案设计中,想使用最简单的Sehll脚本进行同步,但是会出现以下几个问题要解决:
- 在前期配置过程中,如果待同步项目较多,则在目标端进行预配置的工作较多,增加了管理成本,所以希望将整组的项目进行完整的增量同步
- 如果在源端有新的代码库增加,则需要至少维护同步脚本和备份端的Gitlab环境进行修改
- 如果还想同步Gitlab上诸如Wiki等文档类页面,则需要额外的手段进行
解决过程及思考
基于以上几点考虑,期望寻求一种自动化手段解决该问题,争取实现零运维的效果。
方案一:利用Gitlab原生机制
在Gitlab中提供了一种仓库(projects)级别的同步方式,具体配置如下:
- 进入仓库的的Settings,点击Repository
- 打开Mirroring repositories
- 配置目标仓库地址及同步方式
在开源版本中,只支持Push方式,而商业版本则支持Push和Pull两种方式。这个功能的优势是实时性,每当有代码提交后,则自动触发同步,避免了不必要的负载。
但是遗憾的是,在本地进行了测试时,只显示正在同步,但是一直没有同步成功,也没有给出具体的任务状态或失败原因。同时,并没有在组级别上提供同步能力,每次新增项目时,仍然需要手动在源端和目标端进行频繁操作,维护成本较高,所以最终放弃了该方案。
方案二:开源项目
在放弃第一个解决方案后,开始在Github上寻找开源项目。有一个基于Shell开发的gitlab-mirrors的项目引起了我的关注,这个项目由多个shell脚本组成。目标端支持除gitlab之外的多种Git仓库,看起来可以满足我们的需要。但是经过调研,发现gitlab-mirrors是以project为单位,无法按照组级别进行同步,所以也无法满足我们的需要。经过多番搜索,并没有一个项目能够百分之百满足我们组级别同步备份需求的项目。
方案三:自主实现自动化流程
由于以上两种方式均无法满足需求,所以决定基于Gitlab开放的Python库进行二次开发,满足需求。基本的思路为:
- 在源端获取待同步组内的所有项目、子组
- 克隆代码、所有分支、tags
- 判断目标端Gitlab是否存在该组或者项目,如果没有则创建
- Push代码、分支、tags
在满足了以上需求后,需要定期执行脚本实现周期性增量同步,那么如何利用Docker实现最简单的部署呢?所以需求进一步更新为:
- 构建一个容器,该容器能够支持定期执行同步任务
- 容器要利用系统的crontab,支持灵活配置
- 任务在执行时要避免重复执行
基于以上需求,我开发了gitlab-sync脚本及容器(https://github.com/xiaoquqi/gitlab-sync),改代码已经上传到github中,以下就为大家介绍详细的使用方法。
使用方法
通过以下配置,你可以轻松完成从Gitlab A中的Group A周期同步至Gitlab B中的Group B中。
前提条件
在开始配置gitlab-sync前,以下信息是必须提前获取的:
- LOCAL_GTILAB_URL: 源端的Gitlab的WEB地址及端口
- LOCAL_GITLAB_TOKEN: 源端Gitlab的Token,需要读取的权限
- LOCAL_GITLAB_GROUP: 源端Gitlab待同步的组,该组下所有项目及后续新增项目都会自动同步到目标端
- REMOTE_GTILAB_URL: 目标端Gitlab的WEB地址及端口
- REMOTE_GTILAB_TOKEN: 目标端Gitlab的Token,需要读取和写入权限
- REMOTE_GTILAB_GROUP: 目标端的组,可以与源端不一样
- REMOTE_GTILAB_PUSH_URL: 目标端Push地址,用于作为git push的目标端
除了这些信息外,Docker启动会默认将$HOME/.ssh路径挂载至容器内,所以需要你的key已经加入到源端和目标端的Gitlab中,以保证正确的Clone和Push的操作。
获取代码及配置
在代码中,提供了docker-compose.yml文件,可以直接使用。
git clone https://github.com/xiaoquqi/gitlab-sync
cd gitlab-sync
cp env.sample .env
cp crontab/cron.exmaple crontab/cron
- 在.env文件中,根据提前准备好的变量进行配置
- cron是crontab的配置文件,根据需求设定周期同步策略,后面的命令行不建议修改,其中flock是为了避免任务被重复运行
启动同步
完成配置后,启动容器开始同步。
docker-compose up -d
可以在Host主机的/var/log/gitlab-sync/gitlab-sync.log获取执行过程中的日志。
总结
在整个过程中,原本是想以脚本方式做最简单的处理,但是考虑到了后期运维成本等问题,最终决定考虑一种全自动化方式进行运维。
在处理容器运行crontab时,遇到用户环境变量无法获取的问题,目前采用的一种方式是一种Work Around,在容器启动后,将当前用户环境变量Dump到根分区下固定文件,在执行period_task.sh脚本中去加载这个脚本,从而获取环境变量。如果有更好的方法进行优化,欢迎提交Pull Request。
如果大家在使用过程中有任何问题,欢迎反馈,我会持续优化代码。
- 上一篇:gitlab小白安装教程
- 下一篇:群晖使用Docker安装并配置GitLab服务器
相关推荐
- Python 实现 | 通过 Gitlab API 获取项目工程、分支、commit 提交记录
-
前提在gitlab中你的工程创建AccessToken然后你会得到一个21位accesstoken,代码中需要用到。代码...
- 还在用Jenkins?试试Gitlab的CI/CD功能吧,贼带劲
-
原文链接:https://mp.weixin.qq.com/s/hyGkjsRIIZdiF_bG-WqLnQ原作者:macrozheng最近发现Gitlab的CI/CD功能也能实现自动化部署,用起来也...
- 使用GitLab实现CICD
-
GitLabCI/CD是一个内置在GitLab中的工具,用于通过持续方法进行软件开发:ContinuousIntegration(CI)持续集成ContinuousDelivery(C...
- 配置GitLab流水线和门禁系统
-
在项目开发的过程中,为了保证代码质量,我们会使用诸多代码质量检测工具,这些工具或是在本地,或是在云端,虽然工具可以检测出异常问题,但是这些问题还是需要我们程序员来修复,如果我们不强制所有人必须修复异常...
- 害怕代码操作是“黑盒”,用代码审计将操作变”白盒”
-
本文作者:极狐GitLab资深解决方案架构师尹学峰审计事件使用审计事件来跟踪重要事件,包括执行相关操作的人员和时间。您可以使用审计事件来跟踪例如:...
- CentOS 7下Yum及RPM安装GitLab CE 14.0.3
-
一、概述 GitLab是一个利用RubyonRails开发的开源应用程序,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。它拥有与GitHub类似的功能,能够浏览源代...
- centos7安装部署gitlab
-
一、Gitlab介1.1gitlab信息GitLab是利用RubyonRails一个开源的版本管理系统,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。与Githu...
- nginx日志文件切割
-
使用脚本对nginx日志文件进行按天切割#!/bin/bashLOGS_PATH=/usr/local/nginx/logsYESTERDAY=$(date-d-1day+%Y%m%d)c...
- GitLab实战操作指南
-
一、Git原理1、Git是什么?Git是目前世界上最先进的分布式版本控制系统(没有之一)。...
- 单点登录平台Casdoor搭建与使用,集成gitlab同步创建删除账号
-
一,简介一般来说,公司有很多系统使用,为了实现统一的用户名管理和登录所有系统(如GitLab、Harbor等),并在员工离职时只需删除一个主账号即可实现权限清除,可以采用单点登录(SSO)...
- 每日一招:搭建Jenkins,Gitlab自动化打包部署项目
-
每日一招,每日掌握一个要点,日积月累的积累。虽然成为不了大神,大牛,但是养家糊口还是可以的。1.Docker-compose构建jenkins环境1.1创建docker在主机的jenkins数据映射...
- Gitlab替代,开源,轻量级代码托管解决方案
-
前言Gitea是一款基于go开发,轻量级的开源跨平台代码托管方案,适合中小团队之间的文档共享和代码协作。主要功能如下:代码托管,支持git代码推拉和版本控制,问题跟踪,允许创建私有或公开仓库;支持ap...
- 基于Docker构建安装Git/GitLab,以及制作springboot工程镜像
-
今天给大家分享的是《领先的开源自动化服务器Jenkins的应用实战》之基于Docker安装构建Git/GitLab版本控制与代码云存储的场所;使用Git管理项目,springboot工程制作镜像知识体...
- Gitlab不同方式的安装配置及常见场景用法
-
一:rpm格式安装1.安装对应的依赖包yuminstall-ycurlpolicycoreutils-pythonopenssh-serversystemctlenablesshdsy...
- 群晖使用Docker安装并配置GitLab服务器
-
群晖(Synology)内置的GitLab版本已经很老了,虽然对系统资源的利用较少,但是不利于使用。因此,要在群晖上安装GitLab服务器,最好还是通过内置的Docker进行安装,这样可以安装较新的G...
- 一周热门
-
-
一文读懂关于MySQL Datetime字段允许插入0000-00-00无效日期
-
MySQL数据库关于表的一系列操作 mysql 表操作
-
新版腾讯QQ更新Windows 9.9.7、Mac 6.9.25、Linux 3.2.5版本
-
IDC机房服务器托管可提供的服务
-
一款全能的看图软件,速度快、功能强、免费用
-
Boston Dynamics Founder to Attend the 2024 T-EDGE Conference
-
一文看懂mysql时间函数now()、current_timestamp() 和sysdate()
-
深度测评:Pixave 和图片管理之间的距离(二)
-
每天一个入坑小技巧:MySql和oracle语法区别(今日追加)
-
Serv-u 提权
-
- 最近发表
- 标签列表
-
- mysql 时间索引 (31)
- mydisktest_v298 (34)
- document.appendchild (35)
- 头像打包下载 (61)
- acmecadconverter_8.52绿色版 (39)
- oracle timestamp比较大小 (28)
- word文档批量处理大师破解版 (36)
- server2016安装密钥 (33)
- mysql 昨天的日期 (37)
- 加密与解密第四版pdf (30)
- jemeter官网 (31)
- parsevideo (33)
- 个人网站源码 (37)
- exe4j_java_home (30)
- centos7.4下载 (33)
- xlsx.full.min.js下载 (32)
- mysql 查询今天的数据 (34)
- intouch2014r2sp1永久授权 (36)
- 先锋影音源资2019 (35)
- usb2.0-serial驱动下载 (30)
- vs2010官网 (31)
- python核心编程第四版pdf (32)
- jdk1.8.0_191下载 (33)
- layer icon (32)
- axure9注册码 (33)