- 开发无止境 -
Data: 2019-07-09 17:14:25Form: JournalClick: 13
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
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 = *
echo "admin:qiushanyue" > /etc/rsyncd.passwd
chmod 600 /etc/rsyncd.passwd
启动服务
systemctl start rsyncd
设置开机启动
systemctl enable rsyncd
查看服务状态
systemctl status rsyncd
首先查看服务器上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
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
执行命令:crontab -e
(此处编辑与Vim用法一样,按i 输入下放指令,添加完按esc 然后输入:wq)
0 * * * * /root/rsyncd.sh
crontab 设置规则