双向实时远程同步文件(inotify+rsync与nfs)
2013-10-05 11:48:19 点击:

项目中遇到两台机子上文件需要实时同步的情况,尝试了下面两种方法:项目要求:A机(190)与B机(217)要求一个文件夹内容同对方一致,A机与B...
        项目中遇到两台机子上文件需要实时同步的情况,尝试了下面两种方法:
项目要求:A机(190)与B机(217)要求一个文件夹内容同对方一致,A机与B机都有可能单独接收到文件从而同步到对方。
方法一、 使用rsync-server与inotify配合同步文件
1、rsync-server配置(217)
1
2
3
4
5
6
7
8
9
10
11
12
13
# vi /etc/xinetd.d/rsync
# default: off
#       allows crc checksumming etc.
service rsync
{
        disable = no
        socket_type     = stream
        wait            = no
        user            = root
        server          = /usr/bin/rsync
        server_args     = --daemon
        log_on_failure  += USERID
}
2、指定文件位置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# vi /etc/rsyncd.conf
uid = root
gid = root
use chroot = yes
max connections = 4
strict modes = yes
syslog facility = local5
port = 873
[backup]
path = /home/rsync/test/  ##要同步的文件夹
comment = This is a test
ignore errors
read only = no   ##写权限
list = yes
auth users = rsync
secrets file = /etc/rsync.pas   ##验证文件,对方机子也要存在这个文件
hosts allow = 192.168.1.190 ##客户端IP
3、创建rsync.pas
1
2
# vi /etc/rsync.pas
sync:test
4、客户端同步脚本(190)
1
2
3
4
5
6
7
8
vi inotify_rsync.sh
#!/bin/bash
SRC=/home/rsync/test/
DST=rsync@192.168.1.217::backup
/usr/bin/inotifywait -mrq -e modify,<del datetime="2011-11-07T01:44:44+00:00">delete</del>,create,attrib ${SRC} | while read D E F
do
/usr/bin/rsync -ahqzt --progress <del datetime="2011-11-07T01:44:44+00:00">--delete</del> --password-file=/etc/rsync.pas $SRC $DST
done
5、设置脚本开机自启动
1
# cat "/root/inotify_rsync.sh &" >> /etc/rc.local
6、双向同步的实现及存在问题 以上只是实现A机(190)同步到B机(217)的操作,把配置改一下在A机(190)上建立rsync服务器,即可实现双向同步,但不能执行删除操作,因为它们并没有方法判断以谁的操作为主,会造成新建文件被删除。

方法二、使用NFS共享服务器实现文件同步
1、配置NFS
1
2
3
4
5
#service portmap start
#service nfs start
#vi /etc/exports
/home/rsync/test *(rw,sync,no_root_squash) ##rw:可读写的权限;sync:资料同步写入存储器中; no_root_squash: 登入到NFS主机的用户如果是ROOT用户,他就用有ROOT的权限
# exportfs -rv  ##重新将设定加载
2、加载NFS共享目录 加载之前先用SSH连接一下两台机子,这样就不用配验证了,再写入到/etc/fstab文件里就OK了。
1
mount -t nfs 192.168.1.190:/home/rsync/test /home/rsync/test
写在最后:方法一文件同时存在两台机子上,具有实时性,安全性,但只适合不执行删除的文件的环境;方法二文件只存在于NFS服务器上,如果配合rsync服务器定时备份到另一地方,出现故障时可以人工恢复,也是不错的选择。

本文出自 “kras-linux” 博客,请务必保留此出处http://klinux.blog.51cto.com/2972664/708294



相关热词搜索:双向 实时 远程

上一篇:nfs搭建 centos 6.x
下一篇:利用rsync实现数据远程容灾备份