Linux rsync 如何实现自动文件同步?
邱冬夏 于 2022-05-31 11:54:30 发布 3372 收藏 8
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
一、基础环境
rsync是linux系统下的数据镜像备份工具。使用快速增量备份工具Remote Sync可以远程同步,支持本地复制,或者与其他SSH、rsync主机同步。
本文是利用rsync实现在不同Linux服务器上的文件进行周期同步,有A、B两台服务器,A的IP为192.168.204.206,B的IP为192.168.204.204;
》A、B服务器的系统版本:
cat /etc/redhat-release
CentOS Linux release 7.6.1810 (Core)
》默认CentOS7有安装rsync软件,通过如下命令可以查看:
rpm -qa | grep rsync
》如果没有安装通过如下命令进行安装:
yum install rsync -y
二、服务端Server-A的配置流程
1、编辑配置文件,在默认配置下方添加如下配置
vim /etc/rsyncd.conf
#安全相关
use chroot = no
#是否只读
read only = no
#同步文件所属用户名
uid = appdeploy
#同步文件所属用户组
gid = mwopr
#最大链接数
max connections = 20
#模块名称
[transport1]
#同步的文件路径
path = /tmp/roles
#忽略错误程序
ignore errors
#用于认证的账户
auth users = admin
#用于认证的密匙文件
secrets file = /etc/rsyncd.passwd
#准许访问rsync服务端的客户端IP地址范围
hosts allow = 192.168.204.0/255.255.255.0
#禁止访问rsync服务端的客户端IP地址范围
hosts deny = *
2、创建用于认证的文件
echo "admin:qiushanyue" > /etc/rsyncd.passwd
3、对文件进行授权(重要)
chmod 600 /etc/rsyncd.passwd
4、启动服务
启动服务
systemctl start rsyncd
设置开机启动
systemctl enable rsyncd
查看服务状态
systemctl status rsyncd
5、设置防火墙
首先查看服务器上rsync服务的端口
netstat -antup | grep rsync
如图端口为tcp 873,进行防火墙策略放通
firewall-cmd --zone=public --add-port=873/tcp --permanent
firewall-cmd --reload
查看防火墙已经放通873端口
firewall-cmd --list-all
二、客户端服务器进行拉去文件测试
1、创建密码文件并授权
echo "qiushanyue" > /root/passwd
chmod 600 /root/passwd
2、服务端服务器服务器上的/tmp路径下创建roles测试目录,并在下面创建测试文件
mkdir /tmp/roles
cd /tmp/roles
touch boduo cangjing xiaoze
3、在客户端服务器上的/tmp路径下创建roles测试目录并手动同步测试
mkdir /tmp/roles
rsync -avz --password-file=/root/passwd [email protected]::transport1 /tmp/roles
三、设置定时任务实现自动同步
1、创建脚本
touch /root/rsyncd.sh
》在脚本文件中添加拉去文件的指令
vim /root/rsyncd.sh
rsync -avz --password-file=/root/passwd [email protected]::transport1 /tmp/roles >/dev/null 2>&1
》授权脚本文件
cd /root
chmod 755 rsync.sh
2、设置定时任务每小时同步一次
执行命令:crontab -e
(此处编辑与Vim用法一样,按i 输入下放指令,添加完按esc 然后输入:wq)
0 * * * * /root/rsyncd.sh
crontab 设置规则