linux服务器文件实时同步
1 背景说明
在做系统集群部署时,涉及到两个或多个服务器之间文件同步.在软件层面linux服务环境找到以下两种同步方式
- 利用linux NFS功能将网络共享文件挂载成本地目录
- 采用文件监听,实时推送
服务器资源如下
- 服务器1 10.2.4.51 ,作为主服务器
- 服务器2 10.2.4.52 ,作为从服务器
2 NFS网络共享配置
2.1 主服务器
2.1.1 安装应用包
yum install -y nfs-utils rpcbind #nfs安装命令 author: herbert QQ:464884492
systemctl enable nfs #将nfs设置开机启动
systemctl enable rpcbind #将rpcbind设置开机启动
2.1.2 共享配置
主服务建立需要共享的文件夹
mkdir /home/nfs_data # 主服务需要共享的目录
配置从服务可以访问主服务器
vi /etc/exports #author: herbert qq:464884492
设置内容为
/home/nfs_data/ 10.2.4.52(rw,sync,no_root_squash)
重启服务,注意一定要先启动 rpcbind
systemctl stop nfs
systemctl stop rpcbind
systemctl start rpcbind
systemctl start nfs
showmount -e # 可以检查NFS配置是否生效
# 配置正确后,会有一下提示信息
Export list for hk51:
/home/nfs_data 10.2.4.52
2.1.3 防火墙配置
如果服务器需要开启防火墙,需要在防火墙添加服务,可以通过firewall-cmd --state 防火墙开启状态
firewall-cmd --add-service=nfs --permanent --zone=public
firewall-cmd --add-service=mountd --permanent --zone=public
firewall-cmd --add-service=rpc-bind --permanent --zone=public
firewall-cmd --reload #重新载入配置,使其生效
2.2 从服务器
2.2.1 应用包安装
yum -y install nfs-utils
2.2.2 挂载配置
在相同的路径建立同样的目录
mkdir /home/nfs_data # 从服务需要共享的目录
挂载目录
mount -t nfs -o sync,noac 10.2.4.51:/home/nfs_data /home/nfs_data #目录挂载
检查挂载
df -h #查看挂载
配置开机启动挂载
vi /etc/fstab #追加内容 10.2.4.51:/home/nfs_data /home/nfs_data/ nfs sync,noac 0 0
3 文件实时监听同步
3.1 SSH互信配置
主服务器和从服务分别生成自己的公钥,命令如下
ssh-keygen -t rsa -P '' -f ~/.ssh/id_rsa # 生成证书
cd ~/.ssh/ #切换目录
touch authorized_keys #生成认证文件
cat id_rsa.pub >>authorized_keys #复制公钥到认证文件
scp authorized_keys 10.2.4.52:/root/.ssh #远程复制自己公钥到对方服务器
service sshd restart #重启SSH服务
主服务器和从服务器 authorized_keys 文件,保存所有需要免密登录服务器的公钥信息即id_rsa.pub文件中的值
3.2 同步软件安装
主服务器和从服务器同时安装应用包
yum -y install inotify-tools
yum -y install unison #author: herbert qq:464884492
主服务器从服务器在相同路径建立需要实时共享的目录
mkdir /home/sync_data
3.3 同步脚本编写
主服务器(10.2.4.51)监听同步脚本,文件名 /home/runfilesync.sh
#/bin/bash
dstIp="10.2.4.52"
src="/home/sync_data"
dst="/home/sync_data"
/usr/bin/inotifywAIt -mrq -e create,delete,modify,move $src | while read line; do
/usr/bin/unison -batch $src ssh://$dstIp/$dst
echo -n "$line " >> /var/log/inotify.log
echo `date | cut -d " " -f1-4` >> /var/log/inotify.log
done
从服务器(10.2.4.52)监听同步脚本,文件名 /home/runfilesync.sh
#/bin/bash
dstIp="10.2.4.51"
src="/home/sync_data"
dst="/home/sync_data"
/usr/bin/inotifywait -mrq -e create,delete,modify,move $src | while read line; do
/usr/bin/unison -batch $src ssh://$dstIp/$dst
echo -n "$line " >> /var/log/inotify.log
echo `date | cut -d " " -f1-4` >> /var/log/inotify.log
done
3.4 运行脚本,开机自起
脚本需要后台运行,启动命令如下
nohup sh /home/runfilesync.sh &
ps -aux | grep runfilesync #检查脚本是否在运行
#设置开机启动 author: herbert qq:464884492
crontab -e #追加内容 @reboot /home/runfilesync.sh
4 效果测试
- 在主服务器 /home/nfs_data 和 /home/sync_data 两个文件夹中分别添加
touch 地心侠士.txt,然后ssh到从服务,可以在从服务器这两个文件夹中找到地心侠士.text - 在从服务器 /home/nfs_data 和 /home/sync_data 两个文件夹中分别添加
touch 小院不小.txt,然后ssh到主服务,可以在主服务器这两个文件夹中找到小院不小.text
5 总结
通过软件或者协议实现实时同步,以上两种方法各有优劣.采用NFS网络共享协议,必须指定一个网络主节点.采用inotify+unison方式,有点分布式的感觉,无需指定主节点,但同步效果方面和稳定性方面会差一些
文件监听同步软件inotify 和 unison 安装需要编译环境,安装时比较麻烦.我这里提供了rpm安装包以及对应依赖包(安装命令rpm -ivh xxx.rpm).如果需要请关注公众号[小院不小],回复sync获取下载连接,或者添加QQ:464884492,获取
闲暇之余,做了一款有趣耐玩的消除类微信小游戏地心侠士,有兴趣可到微信搜索地心侠士玩玩,感谢支持
上一篇:Docker 与 Linux Cgroups:资源隔离的魔法之旅
栏 目:其它服务器
本文标题:linux服务器文件实时同步
本文地址:https://zz.feitang.co/server/29751.html
您可能感兴趣的文章
- 12-20Kubernetes中使用临时容器进行故障排查的方法
- 12-20Nginx设置HTTPS的方法步骤
- 12-20二进制方式安装 Kubernetes1.18.3版本实现脚本
- 12-20Nginx工作模式及代理配置的使用细节
- 12-20ZooKeeper分布式协调服务设计核心概念及安装配置
- 12-20Kubernetes部署可视化地图的十个步骤
- 12-20关于docker清理Overlay2占用磁盘空间的问题(亲测有效)
- 12-20Docker compose配置文件写法及命令使用示例
- 12-20openwrt安装docker并启动的操作方法
- 12-20云原生Kubernetes初始化容器Init使用教程


阅读排行
推荐教程
- 12-07一文教你怎么选择Tomcat对应的JDK版本
- 12-07新版Eclipse集成Tomcat时找不到server选项的解决方法
- 12-06IIS7 应用程序池自动回收关闭的解决方案
- 12-05Windows Server 2019安装VMware
- 12-05Windows服务器默认IE浏览器无法下载文件的解决方法
- 12-05Docker安装Jenkins全过程
- 12-19Zabbix SAML SSO 登录绕过漏洞的操作流程
- 12-15Docker-Compose搭建Spark集群的实现方法
- 12-14Docker Desktop无法正常启动解决(failed to start...)
- 12-14k8s 与docker空间使用分析与清理方法





