设为首页 收藏本站
查看: 831|回复: 2

[经验分享] Linux(centos5.0+)unison+inotify-tools 触发式双向自动同步

[复制链接]

尚未签到

发表于 2013-6-27 09:01:05 | 显示全部楼层 |阅读模式
192.168.1.11是server1,
192.168.1.22是server2。
【1】安装inotify-tools
  各大linux发行版本都有inotify-tools软件包,建议通过yum方式安装:
  [iyunv@server1 ~]#yum install inotify-tools
  [iyunv@server2 ~]#yum install inotify-tools
******说明开始*********************************
  郁闷的是!公司服务器上竟然没有找到inotify-tools这个包!
  于是只能网上搜包,编译安装了:
  [iyunv@server1 ~]# wget http://github.com/downloads/rvoi ... y-tools-3.14.tar.gz
  [iyunv@server1 ~]# tar xzvf inotify-tools-3.14.tar.gz
  [iyunv@server1 ~]# cd inotify-tools-3.14
  [iyunv@server1 ~]# ./configure
  [iyunv@server1 ~]# make
  [iyunv@server1 ~]# make install

  [iyunv@server2 ~]# wget http://github.com/downloads/rvoi ... y-tools-3.14.tar.gz
  [iyunv@server2 ~]# tar xzvf inotify-tools-3.14.tar.gz
  [iyunv@server2 ~]# cd inotify-tools-3.14
  [iyunv@server2 ~]# ./configure
  [iyunv@server2 ~]# make
  [iyunv@server2 ~]# make install  
******说明结束*********************************
【2】安装unison
通过源码包编译安装unison,需要Objective Caml compiler。
1)安装ocaml到/usr/local/src(建议版本3.0以上,安装路径可自己定义)
  [iyunv@server1 ~]# cd /usr/local/src  
  [iyunv@server1 src]# wget http://caml.inria.fr/pub/distrib/ocaml-3.12/ocaml-3.12.1.tar.gz
  [iyunv@server1 src]# tar -zxvf ocaml-3.12.1.tar.gz
  [iyunv@server1 src]# cd ocaml-3.12.1
  [iyunv@server1 ocaml-3.12.0]# ./configure
  [iyunv@server1 ocaml-3.12.0]# make world opt
  [iyunv@server1 ocaml-3.12.0]# make install
2)编译安装unison(unison版本可以自行去网上下载)
  [iyunv@server1 src]# wget http://www.seas.upenn.edu/~bcpie ... ison-2.40.63.tar.gz
  [iyunv@server1 src]# tar -xzvf unison-2.40.63.tar.gz
  [iyunv@server1 src]# cd unison-2.40.63
  [iyunv@server1 unison-2.40.63]# make UISTYLE=text
  [iyunv@server1 unison-2.40.63]# make install
******说明开始*********************************
  执行make install过程中,可能会出现以下错误提示:
  mv: cannot stat '/root/bin//unison': No such file or directory
  make: [doinstall] Error 1 (ignored)
  cp unison /root/bin/
  cp: cannot create regular file '/root/bin/': Is a directory
  make: *** [doinstall] Error 1
  用百度在线翻译了一下,大致意思是:找不到/root/bin目录。
  因为unison默认是将unison文件拷贝到/root/bin目录,但Linux默认没有该目录,所以我们需要将生成的可执行文件unison复制到系统PATH目录。
  [iyunv@server1 unison-2.40.63]# whereis $PATH  //查看系统PATH目录
   bin: /usr/local/bin
  [iyunv@server1 unison-2.40.63]# cp unison /usr/local/bin  
******说明结束*********************************
3)将可执行文件unison上传到server2主机
  [iyunv@server1 unison-2.40.63]# scp unison root@192.168.1.22:/root/
******说明开始*********************************
  远程连接可能会出现:
  Are you sure you want to continue connecting (yes/no)?
  别犹豫,敲个 yes 吧,然后出现:
  root@192.168.1.22's password:
  别发呆,输入server2的密码吧,然后出现:
  unison               100% 1473KB   36k/s   00:40
  说明unison已经成功上传至server2了。
  双机没配置信任key之前,你远程连接都需要输入密码滴!
******说明结束*********************************
4)登陆server2主机,将unison复制到PATH目录
  [iyunv@server2 ~]# cp unison /usr/local/bin
【3】配置双机信任(ssh key)  
1)server1创建key
  [iyunv@server1 ~]# ssh-keygen -t rsa
******说明开始*********************************
  是不是出现了好多英文句子,看不懂不怪你,我也看不懂,哈哈!
  用百度在线翻译一下,大致意思是:什么公钥,密钥存放位置了,是否需要私钥密码了之类的。
  别理会,敲回车就成!之后,将生成一对密钥,id_rsa(私钥文件)和id_rsa.pub(公钥文件),保存在/root/.ssh/目录下。
******说明结束*********************************
2)将server1的公钥添加到server2的authorized_keys文件
  --将钥文件传到server2主机
  [iyunv@server1 ~]# scp ~/.ssh/id_rsa.pub root@192.168.1.22:/root
******说明开始*********************************
  远程连接可能会出现:
  Are you sure you want to continue connecting (yes/no)?
  别犹豫,敲个 yes 吧,然后出现:
  root@192.168.1.22's password:
  别发呆,输入server2的密码吧,然后出现:
  id_rsa.pub                 100%  394     0.4KB/s
  说明公钥已经成功上传至server2了。
  双机没配置信任key之前,远程连接都需要输入密码滴!
******说明结束*********************************
  --登录server2,将公钥添加到authorized_keys文件中
  [iyunv@server2 ~]# mkdir .ssh
  [iyunv@server2 ~]# chmod 700 .ssh
  [iyunv@server2 ~]# mv ~/id_rsa.pub ~/.ssh/authorized_keys
  [iyunv@server2 ~]# chmod 600 ~/.ssh/authorized_keys
3)server2创建key
  [iyunv@server2 ~]# ssh-keygen -t rsa
******此处说明参看上面**************************
4)将server2的公钥添加到server1的authorized_keys文件
  --将钥文件传到server1主机
  [iyunv@server2 ~]# scp ~/.ssh/id_rsa.pub root@192.168.1.11:/root
******此处说明参看server1**************************
  --登录server1,将公钥添加到authorized_keys文件中
  [iyunv@server2 ~]# mv ~/id_rsa.pub ~/.ssh/authorized_keys
******说明开始*********************************
  此处不用新建.ssh文件夹,不用chmod权限了?
  server1当时创建key时候,.ssh等文件夹就已经存在了!
******说明结束*********************************
5)重启server1,server2的ssh服务
  [iyunv@server1 ~]# /etc/init.d/sshd restart
  [iyunv@server2 ~]# /etc/init.d/sshd restart
【4】测试是否配置成功  
  [iyunv@server1 ~]# ssh root@192.168.1.22  date
  [iyunv@server2 ~]# ssh root@192.168.1.11  date
  不用提示输入密码即可互相得到对方的时间,就证明配置成功了。
【5】使用说明
  在任意一个server机上执行unison命令:
  [iyunv@server1 ~]# unison -bath /home/server1image/ ssh://192.168.1.22//home/server2image/
【6】创建.sh脚本来执行同步
1)server1上创建脚本unison2.sh:
#/bin/bash
ip2="192.168.1.22"
src2="/home/server1image/"
dst2="/home/server2image/"

/usr/bin/inotifywait -mrq -e create,delete,modify,move $src2 | while read line; do
/usr/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
2)server2上创建脚本unison1.sh:
#/bin/bash
ip1="192.168.1.11"
src1="/home/server2image/"
dst1="/home/server1image/"

/usr/bin/inotifywait -mrq -e create,delete,modify,move $src1 | while read line; do
/usr/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
【7】执行.sh脚本
  server1,server2各自执行.sh即可。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-6776-1-1.html 上篇帖子: Linux下做双向同步 下篇帖子: Linux /etc/passwd 文件结构 Linux

尚未签到

发表于 2013-8-9 05:15:39 | 显示全部楼层
所有刻骨铭心的爱都灵魂游离于床上的瞬间!

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

尚未签到

发表于 2013-11-28 16:48:15 | 显示全部楼层
っ 今天陽光好刺眼 陽光下旳迩那麼可愛

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表