阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Linux下inotify+unison双向同步环境部署

143次阅读
没有评论

共计 2635 个字符,预计需要花费 7 分钟才能阅读完成。

在 Linux 下使用 unison+inotify 实现 web 数据双向同步,当其中一台服务器宕机,也不会影响 web 的访问。(ps:之前一直喜欢 nfs,配置非常简单,但是其有个致命的缺点就是其中一台 web 服务挂掉之后,会直接导致 web 页面无法访问)。

环境部署,有如下两台服务器需要做双向同步

192.168.10.1 是 server1,

192.168.10.2 是 server2

第一步,保证两台服务器之间可以通过 ssh 无密码访问,操作如下(这里以 root 用户为例):

分别在 server1 和 server2 下,创建秘钥

mkdir ~/.ssh
 chmod 700 ~/.ssh
生成 RSA 密钥
ssh-keygen -t rsa
 (然后连续三次回车)

添加密钥到授权密钥文件中
 

cd ~/.ssh
 ssh “-p 22” 192.168.10.1 cat /root/.ssh/id_rsa.pub >> authorized_keys  #小写 p
 ssh “-p 22” 192.168.10.2 cat /root/.ssh/id_rsa.pub >> authorized_keys
 scp  -P 22 authorized_keys 192.168.10.2:/root/.ssh/  #大写 P

chmod 600 /root/.ssh/authorized_keys
在服务器 server2 上操作
chmod 600 /root/.ssh/authorized_keys
分别在两台机器上执行如下测试
ssh -p 22 192.168.10.1 date
 ssh -p 22 192.168.10.2 date

至此用户授权完成。

 第二步,软件安装,server1 和 server2 都得安装

安装 unison
首先安装 ocaml,版本至少为 3.07 或更高
 下载地址:http://caml.inria.fr/pub/distrib/ocaml-3.10/
 tar xf ocaml-3.10.2.tar.gz
 cd ocaml-3.10.2
 ./configure
 make world opt
 make install
 cd ..

安装 unison

下载地址:http://www.seas.upenn.edu/~bcpierce/unison//download/releases/unison-2.13.16/
 tar xvf unison-2.13.16.tar.gz
 cd unison-2.13.16
 make UISTYLE=text THREADS=true STATIC=true
cp unison /usr/local/bin
 cd ..

安装 inotify

下载地址:http://inotify-tools.sourceforge.net
 tar xvf inotify-tools-3.14.tar.gz
 cd inotify-tools-3.14
 ./configure
 make
 make install
 cd ..

到此所需的软件都已安装完毕,可以在 server1 服务器上执行这个命令,来查看两台服务器之间是否可以同步文件,unison -batch /home/server1/ ssh://192.168.10.2//home/server2,如果这时候抱如下错误:

/usr/local/bin/inotifywait: error while loading shared libraries: libinotify
可以执行下这个命令:

ln -sv /usr/local/lib/libinotify* /usr/lib/

执行成功后,看目录下的文件是否同步。

第三步,创建.sh 脚本来执行同步

1)server1 上创建脚本 /root/inotify.sh(chmod a+x /root/inotify.sh):

#/bin/bash
ip2=”192.168.10.2″
src2=”/home/server1/”
dst2=”/home/server2/”
/usr/local/bin/inotifywait -mrq -e create,delete,modify,move $src2 | while read line; do
/usr/local/bin/unison -batch $src2 ssh://$ip2/$dst2
echo -n “$line ” >> /var/log/inotify.log
echo `date | cut -d ” ” -f1-4` >> /var/log/inotify.log
done

1)server2 上创建脚本 /root/inotify.sh(chmod a+x /root/inotify.sh):
#/bin/bash
ip1=”192.168.10.1″
src1=”/home/server2/”
dst1=”/home/server1/”
/usr/local/bin/inotifywait -mrq -e create,delete,modify,move $src1 | while read line; do
/usr/local/bin/unison -batch $src1 ssh://$ip1/$dst1
echo -n “$line ” >> /var/log/inotify.log
echo `date | cut -d ” ” -f1-4` >> /var/log/inotify.log
done

最后分别在 server1 和 server2 上执行上面两个脚本,这样两台服务器的目录会保持相互实时同步了!!!

利用 inotify+rsync 实现 Linux 文件批量更新 http://www.linuxidc.com/Linux/2012-01/52132.htm

inotify-tools+rsync 实时同步文件安装和配置 http://www.linuxidc.com/Linux/2012-06/63624.htm

CentOS 6.5 rsync+inotify 实现数据实时同步备份 http://www.linuxidc.com/Linux/2016-11/137655.htm

rsync+inotify 实现数据自动同步  http://www.linuxidc.com/Linux/2017-03/141996.htm

rsync+inotify 实现数据的实时同步  http://www.linuxidc.com/Linux/2017-01/139778.htm

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-05/143526.htm

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-21发表,共计2635字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中