在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上执行上面两个脚本,这样两台服务器的目录会保持相互实时同步了!!!

Linux unison 效率,Linux下inotify+unison双向同步环境部署相关推荐

  1. 金仓KFS数据双向同步场景部署

    KFS数据双向同步场景部署 数据双向同步场景是两端数据库互为源端和目标端,A端有新的增量数据会同步到B端,B端有增量数据也会同步到A端,并且两端之前有防回环机制,防止A端增量数据同步到B端后再同步到A ...

  2. linux lighttpd php,Ubuntu下搭建Lighttpd+PHP+MySQL环境

    简单的几个命令在Ubuntu下搭建Lighttpd+PHP+MySQL环境,Lighttpd是众多OpenSource轻量级的web server中较为优秀的一个.支持FastCGI, CGI, Au ...

  3. Cetnos环境下inotify+rsync实时同步

    一.介绍 1.1 rsync命令是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件.rsync使用所谓的"rsync算法"来使本地和远程两个主机之间的文件达到同步 ...

  4. Linux下实现文件双向同步

    修改的地方时:私钥和公约处. 其次 vi /root/.unison/default.prf 这个文件在这个位置 root = /tmp/test root = ssh://root@10.10.3. ...

  5. Linux(CentOS 6.7)下配置Mono和Jexus并且部署ASP.NET MVC3、4、5和WebApi(跨平台)

    1.开篇说明 a. 首先我在写这篇博客之前,已经在自己本地配置了mono和jexus并且成功部署了asp.net mvc项目,我也是依赖于在网上查找的各种资料来配置环境并且部署项目的,而其在网上也已有 ...

  6. Linux(CentOS 6.5)下配置Mono和Jexus并且部署ASP.NET MVC5

    1.开篇说明 a. 首先我在写这篇博客之前,已经在自己本地配置了mono和jexus并且成功部署了asp.net mvc项目,我也是依赖于在网上查找的各种资料来配置环境并且部署项目的,而其在网上也已有 ...

  7. ubuntu安装eclipse java环境变量配置_【Linux学习】Ubuntu下安装JDK以及配置环境,和eclipse的下载...

    OpenJDK 还是 SunJDK? 由于刚开始接触Linux,所以在搜索如何安装jdk的问题上,有了不同的说法,其中有一种安装是直接安装OpenJDK,还有一种方法下载官方网站的SunJDK,那么两 ...

  8. linux 嵌入式 快照_Linux下搭建Cortex-M嵌入式开发环境

    前言 终于换上了Linux,更换之前考虑良久,最后选定了Ubuntu15(PS:自己家里用的是Fedora),主要是考虑Ubuntu确实更易用(但明显没有Debian和Fedora流畅啊,而且Fedo ...

  9. linux libpcap 效率,Linux ubuntu PF_RING+libpcap 极速捕获千兆网数据包,不丢包

    本文转自:http://blog.chinaunix.net/uid-23225855-id-3228867.html 上一篇文章讲到了,尤其在千兆网的条件下,大量的丢包,网上搜索好久,大概都是PF_ ...

  10. inotify+rsync实时同步服务部署

    环境:服务端 192.168.6.30(安装 rsync) /data/share :客户端 192.168.6.38(安装 inotufy+rsync)/nfsbackup 主流程:https:// ...

最新文章

  1. Centos7 安装 telnet 服务
  2. Oracle:关于分布式数据库(创建数据库链路,创建触发器)
  3. 你们需要的数据集,都给准备好了!
  4. Jmeter使用流程及简单分析监控
  5. python 命令行 解析模块 optparse、argparse
  6. vb.ne textbox数字保存excel_Excel 另类保护:锁死页面布局、保存、审阅标签右键等菜单禁编辑...
  7. 数据库事务4种隔离级别和7种传播行为
  8. 数据持久化基础知识——属性列表
  9. UEditor百度富文本搭建时候遇到的问题
  10. 会考计算机操作题知识点,江西省信息技术会考操作题知识要点汇总
  11. Linux环境变量PATH
  12. java安装后为什么是英文_java用到英语多吗
  13. Ansible—— 29. 通过set_fact模块定义变量
  14. 扣哒世界入选第33届国际信息学奥赛IOI专项赛
  15. 小米四启用虚拟按键以及禁用实体按键
  16. Data Structures in C++:八大基本数据结构概述
  17. Linux 二进制文件调试命令
  18. 什么是编程?该怎么学习编程?
  19. Star ccm+ 算例演示
  20. 关于CH340驱动安装的种种问题的最终稳妥解决办法

热门文章

  1. 翻译 RFC 7322: RFC 样式指南
  2. zzuli2183: 就是签到题XD(欧拉常数)
  3. 夜雨数竞笔记-极限(11)-欧拉常数
  4. springboot + vue 全栈开发实战 读书感想
  5. 前程无忧招聘信息数据清洗+聚类分析
  6. 基于Diffie-Hellman协议 的安全密钥交换的实现原理
  7. 妈妈再也不用担心我的博客访问量了(一个可以刷博客访问量的小程序java)
  8. IE首页被篡改(手动修复)
  9. 今天,你脸上还长痤疮吗?
  10. 大型网站架构:Flickr网站体系结构分析(转)