一、基础环境

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
#最大链接数
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 admin@192.168.204.206::transport1 /tmp/roles

在这里插入图片描述

三、设置定时任务实现自动同步

1、创建脚本

touch /root/rsyncd.sh

》在脚本文件中添加拉去文件的指令

vim /root/rsyncd.sh
rsync -avz --password-file=/root/passwd admin@192.168.204.206::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 设置规则
在这里插入图片描述

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐