------------------------------以下部分在两个节点上执行
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 uid = root gid = root port = 873 use chroot = no max connections = 200 timeout = 600 log file=/var/log/rsync.log pid file=/var/run/rsync.pid lock file=/var/run/rsync.lock [backup] comment = backup path = /home/backup read only = no list = no auth users = rsync secrets file=/etc/rsync.pw
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
Welcome to use the rsync services
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/ [email protected]::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 下创建文件,查看相应的目标服务器是否有文件