基于rsync+inotify-tools 同步geo主从节点的artifacts文件

文章目录

    • [1. 背景](#1. 背景)
    • [2. 操作](#2. 操作)
      • [2.1 geo主节点查看仓库的路径](#2.1 geo主节点查看仓库的路径)
      • [2.2 安装 inotify-tools](#2.2 安装 inotify-tools)
      • [2.3 主从免密](#2.3 主从免密)
      • [2.4 编写同步脚本](#2.4 编写同步脚本)
      • [2.5 同步文件](#2.5 同步文件)
    • [3. 验证](#3. 验证)

1. 背景

由于某个repo的主从artifacts目录偏差非常严重(主节点100G,从节点10G),为了保证主从目录数据的一致性,通过rsync同步来实现。

此外,由于rsync仅仅是同步了主从节点的artifacts文件,其实际并未操作数据库,因为对数据库本身数据不会造成任何影响。

2. 操作

2.1 geo主节点查看仓库的路径

获取当前repo的hash路径:

Menu -> Admin -> Project -> Select Project-> Gitaly相对路径

eg:

Gitaly相对路径是**@hashed/4a/44/4a44dc15364204a80fe80e9039455cc1608281820fe2b24f1e5233ade6af1dd5.git**

则此项目的artifacts路径是:/var/opt/gitlab/gitlab-rails/shared/artifacts/4a/44/4a44dc15364204a80fe80e9039455cc1608281820fe2b24f1e5233ade6af1dd5

2.2 安装 inotify-tools

该工具可以实时监听某个目录的变化,同时触发rsync进行同步。

复制代码
yum install -y inotify-tools

2.3 主从免密

复制代码
ssh-keygen #一路回车即可
ssh-copy-id -i ~/.ssh/id_rsa.pub root@secondary_ip #输入从节点的密码即可

2.4 编写同步脚本

cd /usr/local/src/

cat inotify.sh

复制代码
HOST_IP=10.100.0.2 #从节点ip
MONITOR_DIR=/var/opt/gitlab/gitlab-rails/shared/artifacts/4a/44/4a44dc15364204a80fe80e9039455cc1608281820fe2b24f1e5233ade6af1dd5 #主节点上repo的artifacts目录
DES=/var/opt/gitlab/gitlab-rails/shared/artifacts/4a/44/4a44dc15364204a80fe80e9039455cc1608281820fe2b24f1e5233ade6af1dd5 #从节点上的目标路径
USE=root
CMD=/usr/bin/inotifywait
${CMD} -mrq --timefmt '%Y%m%d %H:%M' --format '%T %w%f%e' -e modify,delete,create,attrib ${MONITOR_DIR} | while read files
do
/opt/gitlab/embedded/bin/rsync -avzP ${MONITOR_DIR}/ --delete --timeout=100  ${USE}@${HOST_IP}:$DES
echo "${files} was rsynced" >>/tmp/rsync.log 2>&1
done

2.5 同步文件

复制代码
cd /usr/local/src/
nohup bash inotify.sh & 
tail -f nohup.out #查看同步的文件信息

3. 验证

通过tree、du -sh等命令查看文件数量和大小。

相关推荐
SEO_juper3 小时前
AI SEO实战:整合传统技术与AI生成搜索的优化框架
人工智能·chatgpt·facebook·seo·geo·aeo
不倒翁玩偶11 小时前
Gitlab拉取代码token换成账号密码登录
gitlab
xixingzhe213 小时前
ubuntu安装gitlab
linux·ubuntu·gitlab
切糕师学AI2 天前
GitLab 是什么?
gitlab
GEO从入门到精通3 天前
AI 关键词匹配度低影响 GEO 优化效果吗?2026实操解析
seo·geo·geo优化
明月心9523 天前
git remote add 用法
gitlab
有颜有货3 天前
GEO(生成引擎优化)是什么?GEO的工作流程详解
人工智能·chatgpt·geo
only_Klein4 天前
jenkins流水线报错:Connection reset by peer
ci/cd·kubernetes·gitlab·jenkins·ssl
机智的投媒网4 天前
GEO时代来临:软文推广平台的转型之路与未来格局
内容运营·geo
梁萌5 天前
docker部署gitlab和gitlab runner
docker·eureka·gitlab