当前位置:  首页  >  服务器技术  >  Linux/unix  >  Linux教程

Linux下Inotify+Rsync文件实时同步

一、使用前言*随着公司业务的发展,单web服务器不能满足用户的访问,需要增加多台web服务器实现均衡高可用性访问。为了统一各web服务器之间的数据随时一致,人工方式肯定是不可取,考虑到需要实时同步,进而采用inotify+rsync的方案进行同步!配置环境:ce

一、使用前言*

随着公司业务的发展,单web服务器不能满足用户的访问,需要增加多台web服务器实现均衡高可用性访问。为了统一各web服务器之间的数据随时一致,人工方式肯定是不可取,考虑到需要实时同步,进而采用inotify+rsync的方案进行同步!

配置环境:centos 5.3 x86_64

rsync版本:rsync-0.3.7

inotify版本:inotify-tools-3.14

服务器端:192.168.2.79 【也是rsync+inotify服务端】

客户端:192.168.2.100 【需要同步,保持数据一致的服务器】

首先下载所需的软件:

http://blog.mgcrazy.com/download/rsync-3.0.7.tar.gz

http://blog.mgcrazy.com/download/inotify-tools-3.14.tar.gz

二、正式安装:

登陆服务端192.168.2.79,下载文件到:/usr/src 下:

cd /usr/src && wget http://blog.mgcrazy.com/download/{inotify-tools-3.14.tar.gz,rsync-3.0.7.tar.gz} && tar xzf rsync-3.0.7.tar.gz && cd rsync-3.0.7 && ./configure ?prefix=/usr/local/rsync &&make &&make install & cd ../ && tar xzf inotify-tools-3.14.tar.gz && cd inotify-tools-3.14 && ./configure &&make &&make install

自此rsync和inotify-tools安装完毕!【可以直接拷贝执行】

三、配置ssh认证:

【目的是为了实时同步的时候不需要输入密码】

在服务端执行这个命令生成公钥:ssh-keygen 一路回车:如下图

然后远程拷贝公钥到客户端服务器并重命名为authorized_keys :

scp -r /root/.ssh/id_rsa.pub root@192.168.2.100:/root/.ssh/authorized_keys 即可!

四、配置实时同步脚本:

#!/bin/sh
src=/home/webapps/www
des=/home/webapps/
ip=192.168.2.100
 
inotifywait -mrq ?timefmt%d/%m/%y-%H:%M’ ?format ‘%T %w%f’ -e modify,delete,create,attrib ${src} | while read file
do
for i in $ip
do
/usr/local/rsync/bin/rsync -aP ?delete $src root@$ip:$des
done
done

保存为rsync.sh 并给执行权限:chmod o+x rsync.sh 这里可以根据实际情况修改需要同步的路径和客户端ip:192.168.2.100 是客户端的ip。

五、测试结果:

剩下就是在后台一直开着这个脚本了:可以用:screen 后台执行; 然后 ./rsync.sh ;crtl+a +d退出,在服务端修改、创建一个文件,相当于一个动作会触发inotify,如果没有动作,默认它是不同步的,然后系统会自动执行rsync同步到客户端,你可以去客户端查看数据!

吐了个 "CAO" !
扫码关注 PHP1 官方微信号
PHP1.CN | 中国最专业的PHP中文社区 | PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | PHP问答
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved PHP1.CN 第一PHP社区 版权所有