1、在Linux下做WEB目录文件同步

一般有如下几种方式:

1)       nfs实现web数据共享

2)       rsync +inotify实现web数据同步

3)       rsync+sersync更快更节约资源实现web数据同步

4)       unison+inotify实现web数据双向同步

他们各有优缺点,这里我根据实际情况,选择方案4。

2、Unison简介

Unison是windows和unix平台下都可以使用的文件同步工具,它能使两个文件夹(本地或网络上的)保持内容的一致。Unison拥有其它一些同步工具或文件系统的相同特性,但也有自己的特点:跨平台使用;对内核和用户权限没有特别要求;Unison是双向的,它能自动处理两分拷贝中更新没有冲突的部分,有冲突的部分将会显示出来让用户选择更新策略;只要是能连通的两台主机,就可以运行Unison,可以直接使用socket连接或安全的ssh连接方式,对带宽的要求不高,使用类似rsync的压缩传输协议。

3、 环境准备如下:

4、安装ocaml

下载:

wget http://caml.inria.fr/pub/distrib/ocaml-4.00/ocaml-4.00.1.tar.gz

解压、安装:

# tar -zxvf ocaml-4.00..tar.gz
# cd ocaml-4.00.
# ./configure
# make world opt
# make install

注意:请下载此版本的ocaml,高版本安装时可能会出错。

5、安装unison

缺少此安装包时下面make步骤会报错:

# yum -y install ctags-etags
# wget http://www.seas.upenn.edu/~bcpierce/unison//download/releases/stable/unison-2.48.4.tar.gz
# mkdir unison-2.48. && cd unison-2.48.
# tar -zxvf /root/unison-2.48..tar.gz
# cd src
# make UISTYLE=text THREADS=true
# cp unison /usr/local/bin/
# unison -version # 有版本信息出现,则安装成功

6、安装inotify

下载链接:http://mirrors.aliyun.com/repo/epel-6.repo
  • 以上安装操作两台机器都需要操作!

  • 到此需要的软件就安装完成了!

7、配置双机ssh信任

在web1上生成密钥,不输入私钥密码:

步骤如下:

[root@web1 ]# ssh-keygen
----- 信息省略,回车三下 --------
[root@ web1 ]# cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys
[root@ web1 ]# chmod ~/.ssh
[root@ web1 ]# chmod ~/.ssh/authorized_keys
[root@ web1 ]# rsync -avz /root/.ssh/authorized_keys
[root@ web1 ]# rsync -avz /root/.ssh/authorized_keys root@192.168.239.62:/root/.ssh/authorized_keys

web2同理!

8、配置双机web目录同步

8.1、Web1上操作:

[root@web1 ]# mkdir -p /root/.unison/
[root@web1 ]# vim /root/.unison/default.prf
---------------- 配置信息如下 ------------------

#Unison preferences file

root = /opt/html/
root = ssh://root@192.168.239.62/ /opt/html/
#force =
#ignore =
batch = true
maxthreads =
#repeat =
#retry =
owner = true
group = true
perms = -
fastcheck = false
rsync = false
sshargs = -C
xferbycopying = true
log = true
logfile = /root/.unison/unison.log
----------------------------------------

8.2、Web2上操作:

[root@web2 ]# mkdir -p /root/.unison/
[root@web2 ]# vim /root/.unison/default.prf
---------------- 配置信息如下 ------------------

#Unison preferences file

root = /opt/html/
root = ssh://root@192.168.239.61/ /opt/html/
#force =
#ignore =
batch = true
maxthreads =
#repeat =
#retry =
owner = true
group = true
perms = -
fastcheck = false
rsync = false
sshargs = -C
xferbycopying = true
log = true
logfile = /root/.unison/unison.log
----------------------------------------

9、在两台机器都添加如下脚本,并使用nohup方式运行。

[root@web1 ~]# mkdir /script
[root@web1 ~]# vim /script/inotify.sh
------------- 脚本信息如下 -------------

#/bin/bash

src="/opt/html/"
/usr/bin/inotifywait -mrq -e create,delete,modify,move $src | while read line; do
/usr/local/bin/unison
echo -n "$(date +%F-%T) $line" >> /var/log/inotify.log
done
--------------------------------------------------------------------------
[root@web1 ~]# chmod +x /script/inotify.sh                               

10、两台机器都需要建立日志目录

如果/var/log/inotify目录没有则需要手工创建,用来存放inotify的日志。

[root@web1 ]# mkdir /var/log/inotify

[root@web2 ~]# mkdir /var/log/inotify

11、将两台机器脚本使用nohup后台运行

如果错误信息输出到日志文件:

[root@web1 ~]# nohup /script/inotify.sh >/dev/null >log &                      

如果错误信息也不想要的话:

[root@web1 ~]# nohup /script/inotify.sh >/dev/null >& &     

12、最后测试

  • 重启电脑,测试二台服务器中/opt/http/的内容是否能同步
  • 不重启电脑,手动执行脚本也可以测试
  • 在其中一台/opt/http/目录中添加,或修改,或删除文件的时候,可以看到脚本状态,同时另一台服务器也应该会跟随操作。

unison+inotify的Web目录同步方案的更多相关文章

  1. 两台linux主机使用unison + inotify实现web文件夹同步

    两台服务器同步数据 unison 是一款跨平台的文件同步对象,不仅支撑本地对本地同步,也支持通过SSH,RSH和Socket 等网络协议进行同步. unison 支持双向同步,你可以同A同步到B ,也 ...

  2. unison+inotify实现数据双向同步

    unison是一款跨windows/linux/MAC OS平台的文件同步工具,不仅支持本地对本地同步,也支持通过SSH.RSH和Socket等网络协议进行同步.更棒的是,unison支持双向同步操作 ...

  3. unison+inotify 同步web代码并排除指定目录不同步

    unison + inotify  实现web 数据双向同步   unison 是一款跨平台的文件同步对象,不仅支撑本地对本地同步,也支持通过SSH,RSH和Socket 等网络协议进行同步.unis ...

  4. 实现web数据同步的四种方式

    http://www.admin10000.com/document/6067.html 实现web数据同步的四种方式 1.nfs实现web数据共享 2.rsync +inotify实现web数据同步 ...

  5. linux下实现web数据同步的四种方式(性能比较)

    实现web数据同步的四种方式 ======================================= 1.nfs实现web数据共享2.rsync +inotify实现web数据同步3.rsyn ...

  6. windows,linux下SVN实现自动更新WEB目录

    通过SVN进行版本库管理,每次提交后,都要在SVN服务器更新最新上传的版本到WEB目录进行同步.操作比较烦琐,而且效率也低.使用SVN钩子脚本进行WEB目录同步,可很好的解决这方面的问题.由于测试机器 ...

  7. linux web服务器静态资源的处理 unison+inotify双向同步

    linux web服务器静态资源的处理 unison+inotify双向同步 http://monkeyzhu.blog.51cto.com/5764358/1324391 简介 unison可以使两 ...

  8. rsync unison+inotify双向实时同步

    rsync多线程同步 A:文件服务器 ip:10.10.1.10 B:备份服务器 ip:10.10.1.11 1.在B服务器上安装rsync软件 tar xzvf rsync-3.1.0.tar.gz ...

  9. unison + inotify 实现文件实时双向同步部署步骤

    unison + inotify 实现文件实时双向同步部署步骤 一. Unison简介 Unison是Windows.Linux以及其他Unix平台下都可以使用的文件同步工具,它能使两个文件夹(本地或 ...

随机推荐

  1. 人脸姿态校正算法 附完整C++示例代码

    在一些特殊情况下,经常需要依据图像中的人脸,对图片进行倾斜矫正. 例如拍照角度幅度过大之类的情况,而进行人工矫正确实很叫人头大. 那是不是可以有一种算法,可以根据人脸的信息对图片进行角度的修复呢? 答 ...

  2. (转)TCP协议与UDP协议的区别

    TCP协议与UDP协议的区别    首先咱们弄清楚,TCP协议和UCP协议与TCP/IP协议的联系,很多人犯糊涂了,一直都是说TCP/IP协议与UDP协议的区别,我觉得这是没有从本质上弄清楚网络通信! ...

  3. error LNK2038: 检测到“RuntimeLibrary”的不匹配项: 值“MTd_StaticDebug”不匹配值“MDd_DynamicDebug

    属性1. 在工程上右键->属性->c/c++->代码生成->运行库 四个选项及含义分别如下: 1.1 /MDd:MD_DynamicDebug,我理解是 "共享DLL ...

  4. First Scala

    注意的两点: 1. Class or Objcect 在Scala把类和对象明确的分开了. Class相当于模板:Object是Class的实现. 2. main 要测试代码必须使用main def ...

  5. Android动态字符串拼接----%s

    在开发经常遇到字符串中的某一数据或多个数据是动态变化的. 如下图 不要创建3个TextView,暂时不考虑颜色变化的情况,可以用以下做法. <string name="maintain ...

  6. 常用域名记录解释:A记录、MX记录、CNAME记录、TXT记录、AAAA记录、NS记录

    A记录 A记录是用来创建到IP地址的记录. A记录设置技巧 1.如果想创建不带www的记录,即ezloo.com,在主机记录中填写@或者留空,不同的注册商可能不一样. 2.创建多个域名到同一个IP,比 ...

  7. Go 语言集成开发环境 GoLand 更新至 2018.1.3 版本

    GoLand 2018.1.3 已发布,这是一个全新的更新,尽管没有带来明显的针对 Go 语言的特定改进,但还是提供了许多与 UI,JavaScript 和 SQL 支持相关的错误修复和改进. 可通过 ...

  8. Nctf_web_wp

    1.签到题     右键源代码即可2.md5 collision    这个考点是php"=="的弱相等,为何会出现弱加密呢,是因为在比较==两边的时候,会将字符串类型转化为相同, ...

  9. MyISAM和InnoDB的索引实现

    在 MySQL 中,主要有四种类型的索引,分别为: B-Tree 索引, Hash 索引, Fulltext 索引和 R-Tree 索引.我们主要分析B-Tree 索引. B-Tree 索引是 MyS ...

  10. Hibernate入门----配置文件

    一.Hibernate简介 hibernate是一个开源的,轻量级的,持久成ORM框架. Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数 ...