一、为什么要用rsync+sersync架构?
1、sersync是基于inotify开发的,类似于inotify-tools的工具。
2、sersync可以记录下被监听目录中发生变化的(包括增加、删除、修改)具体某一个文件或者某一个目录的名字,然后使用 rsync同步的时候,只同步发生变化的文件或者目录。
二、rsync+inotify-tools与rsync+sersync架构的区别?
1、rsync+inotify-tools
a、inotify只能记录下被监听的目录发生了变化(增,删,改)并没有把具体是哪个文件或者哪个目录发生了变化记录下来;
b、rsync在同步的时候,并不知道具体是哪个文件或目录发生了变化,每次都是对整个目录进行同步,当数据量很大时,整个目录同步非常耗时(rsync要对整个目录遍历查找对比文件),因此效率很低。
2、rsync+sersync
a、sersync可以记录被监听目录中发生变化的(增,删,改)具体某个文件或目录的名字;
b、rsync在同步时,只同步发生变化的文件或目录(每次发生变化的数据相对整个同步目录数据来说很小,rsync在遍历查找对比文件时,速度很快),因此效率很高。
三 项目实践
3.1 准备两台机器
rsync服务器(备份端,目标机器) | 192.168.139.136 | [root@nfs-server /]# uname -r 3.10.0-862.el7.x86_64 |
sersync服务器(数据源,源机器) | 192.168.139.135 | [root@backup /]# uname -r 3.10.0-862.el7.x86_64 |
3.2 在两台机器上都安装rsync
[root@rsync-server /]# yum install -y rsync
[root@backup /]# yum install -y rsync
四 .配置rsync服务器上面的rsync
4.1 编辑配置文件rsyncd.conf
[root@backup /] vi /etc/rsyncd.conf
uid = rsync #设置rsync运行权限为rsync
gid = rsync #设置rsync运行权限为rsync
use chroot = no #默认为true,修改为no,增加对目录文件软连接的备份
max connections = 200 #最大连接数
timeout = 300 #设置超时时间
pid file = /var/run/rsyncd.pid #pid文件的存放位置
lock file = /var/run/rsyncd.lock #支持max connections参数的锁文