首页 > 其他 > 详细

Rsync+inotify-tools数据实时同步

时间:2016-08-17 23:29:49      阅读:279      评论:0      收藏:0      [点我收藏+]

------------------------------以下部分在两个节点上执行

1、防火墙开放873端口(两个节点)

# vim /etc/sysconfig/iptables
-A INPUT -p tcp --dport 873 -j ACCEPT
# /etc/init.d/iptables restart
# /etc/init.d/iptables save

2、关闭selinux(两个节点)

# sed -i "s/SELINUX=.*/SELINUX=disabled/g" /etc/selinux/config
# cat /etc/selinux/config

 

3、建立所需目录,上传软件到soft下(两个节点)

#  mkdir -p  /usr/local/download     (软件下载目录)
#  mkdir -p  /usr/local/backup      (备份文件放置目录)
#  mkdir -p  /usr/local/script       (脚本目录)


 安装相关依赖包(两个节点)

#  yum -y install gcc gcc-c++ make perl wget


 安装rsync(两个节点)

#  cd  /usr/local/download
#  wget https://www.samba.org/ftp/rsync/src/rsync-3.1.2.tar.gz
#  tar xf rsync-3.1.2.tar.gz
#  cd rsync-3.1.2
#  ./configure --prefix=/usr/local/rsync-3.1.2
# echo $?
# make
# echo $?
# make install && echo $?
#  ln -s /usr/local/rsync-3.1.2/ /usr/local/rsync


------------------------------以下在备份节点上配置

1、建立配置文件(备份节点)

#  vim /etc/rsync.conf
port = 873
log file=/var/log/rsync.log
pid file=/var/run/rsync.pid
lock file=/var/run/rsync.lock
secrets file=/etc/rsync.passwd
motd file = /etc/rsyncd.motd
transfer logging = yes
log format = %t %a %m %f %b
syslog facility = local3
#hosts deny=
[backup]
comment= backup
path=/usr/local/backup
use chroot = no
max connections=4
read only = no
uid=root
gid=root
list = no
exclude=test
auth users=work
#hosts allow = 172.16.0.233



添加如下内容:

#pid文件的存放位置

pid file = /var/run/rsync.pid

#日志文件位置,启动rsync后自动产生这个文件,无需提前创建

log file = /var/log/rsync.log

#支持max connections参数的锁文件

lock file=/var/run/rsync.lock

#用户认证配置文件,里面保存用户名称和密码

secrets file = /etc/rsync.pw

#rsync启动时欢迎信息页面文件位置

motd file = /etc/rsyncd.motd

transfer logging = yes

log format = %t %a %m %f %b

syslog facility = local3

#自定义名称

[backup]

#设置需要同步的目录

web path=/usr/local/backup

#模块名称与[backup]自定义名称相同

comment = backup

exclude = blank.png ; spinner.gif ; downsimple.png ; rails.png ; WEB-INF/

#默认端口

port = 873

#设置rsync运行权限为root

uid = root

#设置rsync运行权限为root

gid = root

#设置超时时间

timeout = 600

#最大连接数

max connections = 200

#默认为true,修改为no,增加对目录文件软连接的备份

use chroot = no

#设置rsync服务端文件为读写权限

read only = no

#不显示rsync服务端资源列表

list = no

#允许进行数据同步的客户端IP地址

hosts allow = 172.16.0.233

#可以设置多个目录

 

2、建立密码认证文件(备份节点)

#  vim /etc/rsync.pw
root:123456

3、设置权限(备份节点)

#  chmod 600 /etc/rsync.conf
#  chmod 600 /etc/rsync.pw

4、配置rsyncd.motd文件,开始传送的时候会显示(备份节点)

#  vi /etc/rsyncd.motd

输入以下内容:
###############################
#                                                                        #
#                     hello     everyone                         #
#                                                                        #
###############################

                  _____                &&&&_) )
                  \/,---<                &&&&&&\   \
                  ( )c~c~~@~@   ) —  —&&\   \
                    C  >/                \<  |&/
                    \_O/ -            _`*-‘_/ /
                  ,- >o<-.              / ____ _/
                  /  \/  \            / /\     _)  _)
                 / /|  | |\ \          / /    )      |
                 \ \|  | |/ /          \ \   /          |
                  \_\  | |_/            \ \_          |
                  /_/`___|_\            /_/\____|
                    |   |  |                  \        \ |
                    |   |  |                  `.      )
                    |   |  |                    /    /
                    |__|_|_                 /_/|
                   (____)_)                |\_\_


5、启动rsync服务(备份节点)

# /usr/local/rsync/bin/rsync --daemon --config=/etc/rsync.conf
# ps -ef |grep rsync|grep -v grep
root      38142      1  0 19:36 ?        00:00:00 /usr/local/rsync/bin/rsync --daemon --config=/etc/rsync.conf

6、设置开机启动(备份节点)

#  vim /etc/rc.local
/usr/local/rsync/bin/rsync --daemon --config=/etc/rsync.conf

------------------------------以下在源节点执行

1、建立密码认证文件(源节点)

# vim /etc/rsync.pw
123456

 

2、设置权限(源节点)

 #  chmod 600 /etc/rsync.pw


 

3、测试(源节点)

#  mkdir /usr/local/backup
# /usr/local/rsync/bin/rsync -avzP --port=873 /usr/local/backup/ root@172.16.0.234::backup  --password-file=/etc/rsync.pw

 

查看172.16.0.234 上是否有相应的目录

 

4、安装inotify-tools(源节点)
Linux下支持inotify的内核最小为2.6.13

4.1、查看是否支持inotify,有如下三个文件则表示支持(源节点)

# ll /proc/sys/fs/inotify
-rw-r--r-- 1 root root 0 Aug 17 12:49 max_queued_events
-rw-r--r-- 1 root root 0 Aug 17 12:49 max_user_instances
-rw-r--r-- 1 root root 0 Aug 17 12:49 max_user_watches

 4.2、安装inotify-tools(源节点)

# cd /usr/local/download/
# wget http://github.com/downloads/rvoicilas/inotify-tools/inotify-tools-3.14.tar.gz
# tar xf inotify-tools-3.14.tar.gz
# cd inotify-tools-3.14
# ./configure --prefix=/usr/local/inotify-tools-3.14
# echo $?
# make
# echo $?
# make install && echo $?
# ln -s /usr/local/inotify-tools-3.14/ /usr/local/inotify-tools

4.3、查看是否支持,显示如下表示支持(源节点)

# ll /usr/local/inotify-tools/bin/inotifywa*
-rwxr-xr-x 1 root root 44287 Aug 17 12:54 /usr/local/inotify-tools/bin/inotifywait
-rwxr-xr-x 1 root root 41409 Aug 17 12:54 /usr/local/inotify-tools/bin/inotifywatch

 

5、修改内核参数(源节点)

#  vim /etc/sysctl.conf
fs.inotify.max_queued_events=99999999
fs.inotify.max_user_watches=99999999
fs.inotify.max_user_instances=65535

 

添加以下参数:

#inotify队列最大长度,如果值太小,会出现"** Event Queue Overflow **"错误,导致监控文件不准确

fs.inotify.max_queued_events=99999999

#要同步的文件包含多少目录

fs.inotify.max_user_watches=99999999

#每个用户创建inotify实例最大值

fs.inotify.max_user_instances=65535

 

6、编写监控脚本(源节点)

#  vim  /usr/local/script/inotify.sh
 #!/bin/bash
#目标服务器ip,多个ip用空格分开
dstip="172.16.0.234"
#源服务器同步目录
src=/usr/local/backup
#目标服务器rsync同步目录模块名称
dst=backup
#目标服务器rsync同步用户名
user=root
#目标服务器rsync同步用户的密码在源服务器的存放路径
pwdir=/etc/rsync.pw
#目标服务器rsync同步日志文件
logfile=/var/log/rsync.log
/usr/local/inotify-tools/bin/inotifywait -mrq --timefmt ‘%d/%m/%y %H:%M‘ --format ‘%T %w%f%e‘ -e modify,delete,create,attrib,move $src | while read file
do
for ip in $dstip
 do
/usr/local/rsync/bin/rsync -avzP --port=873   $src $user@$ip::$dst --password-file=$pwdir
echo "${file} was rsynced" >>$logfile 2>&1
 done
done



7、设置脚本权限并启动脚本(源节点)

#  chmod 700 /usr/local/script/inotify.sh
#  sh  /usr/local/script/inotify.sh &

 

8、设置开机启动(源节点)

#  echo "/usr/local/script/inotify.sh & ">>/etc/rc.local

 

9、测试

在源服务器上/usr/local/backup 下创建文件,查看相应的目标服务器是否有文件


Rsync+inotify-tools数据实时同步

原文:http://dongxin.blog.51cto.com/3486403/1839554

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!