rsync 数据同步和sersync数据实时同步服务器
基于三台服务器,部署数据实时同步服务器,一台作为主服务器sersync(推送数据),其余两台作为备用服务器rsync(拉取数据)。
rsync 数据同步
环境:
服务器:172.20.26.167
服务器:172.20.26.198
服务器:172.20.26.24
实现有权限的地址可同步
两台服务器均需安装有rsync服务。
在172.20.26.198上检查是否有安装rsync 服务
[root@localhost ~]# rpm -qc rsync #查询rsync服务的配置文件
未安装软件包 rsync
[root@localhost ~]# yum install rsync -y
data:image/s3,"s3://crabby-images/aa823/aa823820c2d786a79c454a3f6eeb8c11d9871a15" alt=""
[root@localhost ~]# rpm -qc rsync #查询rsync 服务的配置文件
/etc/rsyncd.conf
/etc/sysconfig/rsyncd
[root@localhost ~]# vim /etc/rsyncd.conf #守护模式的配置文件rsyncd.conf,在后台运行的进程,不影响前端的shell
data:image/s3,"s3://crabby-images/42127/421278b6815a65568be940936aa353fd14342ac4" alt=""
把光标移动到uid行首,ctrl+v 进入可视化模式,按向右键,再按向下键,再按x键,去掉#号注释,保留有效参数
修改相关配置参数:
uid = root rsync #进程管理用户
gid = root rsync #进程管理用户
use chroot = yes #安全设置,限制软连接,如果设置为no,则文件同步到远程服务器后,会在链接文件前面增加一个目录,使链接文件失效,设置为yes则表示不加目录。
max connections = 10 #最大链接数
ignore nonreadable = yes #忽略不可读的错误
read only = false #关闭只读权限
hosts allow = 172.20.26.24 #允许同步的服务器
hosts deny = * #不允许同步的服务器,* 代表所有
auth users = rsync #创建同步时使用的虚拟用户
secrets file = /etc/rsync.passwd #将密码写入rsync.passwd 文件,使用该虚拟用户同时时不需要再输入密码
编辑【web】模块、【sql】模块
[web]
path = /data/web
comment = nginx data backup
[sql]
path = /data/sql
comment = sql data backup
data:image/s3,"s3://crabby-images/dae1f/dae1f343aac1bc85348681a4ffca7f9679350262" alt=""
[root@localhost ~]# systemctl start rsyncd
[root@localhost ~]# systemctl status rsyncd
data:image/s3,"s3://crabby-images/29706/2970634a21bcee51a91f8b0b8239608670241add" alt=""
创建配置文件设置的目录路径
[root@localhost ~]# mkdir -p /data/web
[root@localhost ~]# ls
anaconda-ks.cfg
[root@localhost ~]# mkdir -p /data/sql
[root@localhost ~]# ls
anaconda-ks.cfg
[root@localhost ~]#
[root@localhost /]# cp /etc/fstab /data/web #将/etc/fstab 文件拷贝到/data/web 目录下
data:image/s3,"s3://crabby-images/b9006/b9006b27ba1047fa693ff0ec18ae59dbbe07d5be" alt=""
在172.20.26.24服务器上也安装rsync 服务
data:image/s3,"s3://crabby-images/6cff9/6cff94c32f455a8e61d087e05a21765cfe28922e" alt=""
[root@bogon ~]# systemctl start rsyncd #启动rsync服务
从172.20.26.198服务器上拉取web 模块中的文件到当前目录下
[root@bogon ~]# rsync -av 172.20.26.198::web .
data:image/s3,"s3://crabby-images/1adca/1adcafce106fd248c7067cf57f5e3ff113a81f56" alt=""
也可以将本机上的文件(/etc/passwd)推送给172.20.26.198上的web模块里,因在172.20.26.198上的rsync.conf文件中配置了"read only = false 关闭只读权限",否则会报错。
data:image/s3,"s3://crabby-images/7544b/7544ba653cf362c2e9378a0ac705301fde827e11" alt=""
在172.20.26.198上查询推送过来的passwd文件
data:image/s3,"s3://crabby-images/546fd/546fd0d92d7824243686c1e10add1958a88518fa" alt=""
如果需要开启认证的话,需要定义虚拟用户和密码,配置到rsync.conf 文件中
[root@localhost /]# vim /etc/rsyncd.conf
data:image/s3,"s3://crabby-images/4e2f0/4e2f05efb7428abb2fc80b392b1b0e83a936c995" alt=""
如果使用的用户名和密码一样,可以写在全局里,也可以写到模块里,如果不一样,分别写到自己的模块里即可。
data:image/s3,"s3://crabby-images/97949/97949e040099af437eab7b4608681ba6fa9eba78" alt=""
[root@localhost /]# echo "rsync:123456" >/etc/rsync.passwd
[root@localhost /]# chmod 600 /etc/rsync.passwd #修改rsync.passwd 文件的权限,其他人和组不可读写
data:image/s3,"s3://crabby-images/a7246/a72465ac653aabaffdd7e1862fb66519ca7d3b21" alt=""
重启rsync 服务
[root@localhost /]# systemctl restart rsyncd
[root@bogon ~]# rsync -av /etc/yum.conf rsync@172.20.26.198::web
输入rsync 的密码 123456
data:image/s3,"s3://crabby-images/923f0/923f0ac84c0305876857ab95ad920c1ae9d0e7ae" alt=""
在172.20.26.198上查询/data/web 目录下已经有yum.conf 文件
data:image/s3,"s3://crabby-images/e32d2/e32d29343c264e9b94657b281800f868ad6f941b" alt=""
也可以将密码写进文件里,使用这个用户同步数据时不再需要输入密码。
[root@bogon ~]# echo "123456" > /etc/rsync.passwd #将密码写入rsync.passwd 文件中
[root@bogon ~]# chmod 600 /etc/rsync.passwd #取消其他人和组对rsync.passwd 文件读取权限
data:image/s3,"s3://crabby-images/7ba31/7ba316200a06e128336ddffcc12ddb58b2f3ebb7" alt=""
[root@bogon ~]# rsync -av /etc/virc rsync@172.20.26.198::web --password-file=/etc/rsync.passwd
data:image/s3,"s3://crabby-images/75766/75766e7ec4ddf5a6e4e0c9374925ba272e47dd34" alt=""
在172.20.26.198上查询/data/web 目录下已经有virc 文件。
data:image/s3,"s3://crabby-images/43e60/43e604808e374a90c430ae032e1196b903d044dd" alt=""
也可以设置允许某些服务器连接同步,拒绝其他的服务器连接同步。
目前172.20.26.167 服务器是可以将文件推送到172.20.26.198服务器上的,而我们可以设置只允许172.20.26.24 连接同步,拒绝172.20.26.167连接同步。
data:image/s3,"s3://crabby-images/fe9e3/fe9e391d23220712dfd8a4d1f61d38a607b3b30a" alt=""
[root@localhost ~]# vim /etc/rsyncd.conf
data:image/s3,"s3://crabby-images/a0d48/a0d4817481e4a2c67e52d619f9acc532f0f9e6b4" alt=""
[root@localhost ~]# systemctl restart rsyncd
在172.20.26.167上推送sysctl.conf文件到172.20.26.198上,被拒绝
[root@bogon ~]# rsync -av /etc/sysctl.conf rsync@172.20.26.198::web
data:image/s3,"s3://crabby-images/36161/3616171978b584c617077c90d44b140f29615c08" alt=""
我们修改172.20.26.198上的/etc/rsyncd.conf文件,把172.20.26.167 写到允许的hosts 里,即可让172.20.26.167也能向172.20.26.198服务器推送文件
[root@localhost ~]# vim /etc/rsyncd.conf
data:image/s3,"s3://crabby-images/bf0a9/bf0a9887db6dcbf528bd863ac1468b7de97f70a6" alt=""
保存退出,重启rsync服务
[root@localhost ~]# systemctl restart rsyncd
回到172.20.27.167服务器上执行rsync命令,
[root@bogon ~]# rsync -av /etc/sysctl.conf rsync@172.20.26.198::web
data:image/s3,"s3://crabby-images/515bb/515bbf5afb84adead96989ae35294e5d9c0aa7dd" alt=""
将syssctl.conf 推送到172.20.26.198服务器上的web模块中
data:image/s3,"s3://crabby-images/efa2f/efa2ff726ed0bebcc3dca1bfd6b43478c3d76d12" alt=""
我们在/etc/rsyncd.conf 里也配置了sql 模块,也创建了/data/sql 目录,我们也可以用这个模块进行实验。
rsync -av /etc/virc rsync@172.20.26.198::sql --password-file=/etc/rsync.passwd
data:image/s3,"s3://crabby-images/ae8c9/ae8c9e04e765b188626d5b3f93e73b5d6d7ba939" alt=""
data:image/s3,"s3://crabby-images/798b9/798b995152abf52dee5787ffb9309c9bc1c570d2" alt=""
sersync 实时数据同步
环境:
sersync服务器:172.20.26.24 配置sersync 把数据推给167、198
rsync服务器:172.20.26.167、172.20.26.198 配置rsync 接收数据
先在172.20.26.24服务器上配置sersync 服务
[root@bogon ~]# cd /usr/src
[root@bogon src]# rz
将sersync2.5.4_64bit_binary_stable_final.tar上传到172.20.26.24上,配置sersync服务
data:image/s3,"s3://crabby-images/540df/540dfdc4cbf5a9e49ac29f096a163100234bced8" alt=""
[root@bogon src]# tar xf sersync2.5.4_64bit_binary_stable_final.tar.gz
将解压出来的GNU-Linux-x86目录移到/usr/local/sersync
[root@bogon src]# mv GNU-Linux-x86/ /usr/local/sersync
[root@bogon src]# cd /usr/local/sersync
[root@bogon sersync]# ls
confxml.xml sersync2
data:image/s3,"s3://crabby-images/e41ab/e41ab1b3802553596394c0b5985afbc6bfef5550" alt=""
/usr/local/sersync下只有confxml.xml、sersync2两个文件,一个是配置文件、一个可执行文件
[root@bogon sersync]# vim /usr/local/sersync/confxml.xml
将<fileSystem xfs="false"/> 改为 <fileSystem xfs="true"/>
Inotify 模块定义通知开始同步的条件:
<inotify>
<delete start="true"/> #开始删除的时候,默认为true
<createFolder start="true"/> #创建目录的时候,默认为true
<createFile start="false"/> #创建文件的时候,默认为false
<closeWrite start="true"/> #关闭写的时候,默认为true
<moveFrom start="true"/> #从---移动到的时候,默认为true
<moveTo start="true"/> #开始移动的时候,默认为true
<attrib start="false"/> #查询开始,默认为false
<modify start="false"/> #修改开始的时候,默认为false
</inotify>
data:image/s3,"s3://crabby-images/48701/48701de2fa1bcc48018e199e8bb7ddd3c6f028ac" alt=""
配置监控的目录,远程服务器IP地址,要监控的模块,我们之前定义设定的是web
data:image/s3,"s3://crabby-images/a0cf1/a0cf167cca2289eba89764d6bfd36f44e1ee4c1d" alt=""
将超时时间改为true
<timeout start="true" time="100"/><!-- timeout=100 -->
计划任务默认是false ,如果改为true,默认是600分钟做一次全量同步
<crontab start="false" schedule="600"><!--600mins-->
开启认证,配置使用rsync 和密码文件
<auth start="true" users="rsync" passwordfile="/etc/rsync.passwd"/>
保存退出
[root@bogon sersync]# mkdir -p /data/jfedu #创建jfedu目录
[root@bogon sersync]# ./sersync2 -d -r -o /usr/local/sersync/confxml.xml #启动sersync 服务
检查172.20.26.167、172.20.26.198 rsync服务器的服务和目录是否都正常
由于172.20.26.167服务器上没有部署rsync ,可以从172.20.26.198上将rsync的文件拷贝过来
[root@bogon etc]# scp 172.20.26.198:/etc/rsync* /etc/
data:image/s3,"s3://crabby-images/dda36/dda362a91358222346bef5b992069b47abd23080" alt=""
拷贝过来后检查一下rsyncd.conf 没有问题,重启服务
[root@bogon /]# chmod 600 /etc/rsync.passwd #取消其他人和组对rsync.passwd 文件读取权限
创建/data/web 目录
172.20.26.198服务器上rsync 服务和目录都正常
回到172.20.26.24服务器上开始更新/data/jfedu里的数据
[root@bogon sersync]# cp /etc/fstab /data/jfedu/
data:image/s3,"s3://crabby-images/ca032/ca032e608032a638a633762d2723bcc860c89366" alt=""
172.20.26.167服务器上查看data/web 目录下已经有了fstab 文件
data:image/s3,"s3://crabby-images/a9f82/a9f82458c0d2fd3f67225e37dd2f68dc58bc1bd5" alt=""
172.20.26.198服务器上查看data/web 目录下也已经有了fstab 文件
data:image/s3,"s3://crabby-images/7143c/7143cd073f2caa143f6e667c2c3ba93c05697123" alt=""
我们把/etc/passwd 也拷贝到/data/jfedu ,查看同步情况
data:image/s3,"s3://crabby-images/d8172/d817296c0f118d3d5f3eeb685a5e1030179010ee" alt=""
data:image/s3,"s3://crabby-images/fc013/fc0138d99a31a3728abef5a84c66f431d8a8b0eb" alt=""
data:image/s3,"s3://crabby-images/1449c/1449c87717dc4ebc1083e9eae00ab0c9bc27334c" alt=""
对passwd文件内容进行修改,查看同步情况
删除 root:x:0:0:root:/root:/bin/bash 这行信息
data:image/s3,"s3://crabby-images/add38/add380538d188d1b86fa3efc5f12ffbbdc468ae4" alt=""
data:image/s3,"s3://crabby-images/5158a/5158a896f59f8081f7e5627270afccf9aa508861" alt=""
保存退出
在172.20.26.167和172.20.26.198上查看passwd文件里是已经没有刚才删除的信息:root:x:0:0:root:/root:/bin/bash
data:image/s3,"s3://crabby-images/a2976/a2976b8137f6506cf33f0dbc74e5cd73dbb0a917" alt=""
[root@bogon etc]# vim /data/web/passwd
data:image/s3,"s3://crabby-images/1dea7/1dea7b95f0f1b319b2a968731d70a9e13f7e2a83" alt=""
[root@bogon sersync]# tail /tmp/rsync_fail_log.sh #可以查看运行日志
查看sersync 进程
data:image/s3,"s3://crabby-images/3fa5a/3fa5a08619f8d82793a524fb2050a45d438df01c" alt=""