通过rsyncd实现将源服务器上的文件同步到目标服务器,通过lsyncd监控源服务器上的文件是否有变动,若有变动调用rsyncd服务对差异的文件进行同步。
1. 按下图所示在源和目标服务器上安装rsync和lsyncd程序包
2. 目标服务器上安装rsync,并配置
2.1. 安装rsync
$ yum -y install rsync
2.2 修改配置文件 /etc/rsyncd.conf
$ vim /etc/rsyncd.conf
# 启用用户和密码验证,指定文件路径 secretsfile = /etc/rsync.pass [backup] # 同步的目标路径 path = /nq/client # 授权那些源主机 hosts allow = 192.168.0.10,192.168.0.21 # 其它的禁止 hosts deny = * # 启动rsyncd服务的用户和组 uid = root gid = root # 授权连接目标服务器的用户 auth users = rsync
2.3 创建用户和密码文件,并修改权限为600
$ cat /etc/rsync.pass rsync:123456
$ chmod 600 /etc/rsync.pass
2.4 启动服务
$ systemctl start rsyncd
3. 源服务器上安装rsync和lsyncd,并配置lsyncd
3.1 安装rsync
$ yum -y install rsync
3.2 安装lsyncd
$ yum -y install lsyncd
3.3 修改配置文件 /etc/lsyncd.conf
$ /etc/lsyncd.conf
settings { -- 状态存放位置 statusFile = "/tmp/lsyncd.stat", -- 将lsyncd状态写入statusFile文件中的时间间隔 statusInterval = 10, --延迟时间 maxDelays = 1, } sync{ -- rsync, rsyncssh, direct 三种模式 default.rsync, -- 同步的源目录 source="/nq/server/", -- 目标地址 target="[email protected]::backup", -- 同步删除目标文件 delete = true, -- 哪些文件不同步 exclude = {".*"}, rsync = { -- rsync路径 binary = "/usr/bin/rsync", archive = true, compress = true, verbose = true, -- 密码文件 password_file = "/etc/passwd.txt", } }
3.4 将密码存储于以下文件中,并设置权限为600
$ cat /etc/passwd.txt 123456
$ chmod 600 /etc/passwd.txt