1. 前言

  2 台 nginx 需要做集群, 静态文件和php文件都在nginx服务器本地。

  有三种方案:

    (1)NFS

    (2)Rsync + inotify

    (3)共享存储服务器

  第一种:当 nfs server端宕机,全部完蛋,第三种:共享存储服务器单点,如果宕机也完蛋。因此采用 第二种方式:rsync + inotify

2. 环境配置

  2.1 环境介绍

  系统:Centos 7.2 x64

  server端:192.168.118.14

  client端(同步端):192.168.118.15

  2.2 搭建过程

  默认防火墙和selinux 关闭,这里采用 http web服务器测试。

  client 端(同步端)配置:

[root@192.168.118.15 ~]#yum install rsync httpd -y

[root@192.168.118.15 ~]#egrep ^[a-z] /etc/rsyncd.conf
uid = root # 设置rsync运行权限为root
gid = root # 设置rsync运行权限为root
use chroot = no # 默认为true,修改为no,增加对目录文件软连接的备份
max connections = # 最大连接数
timeout = # 设置超时时间
pid file = /var/run/rsyncd.pid # pid文件的存放位置
log file = /var/log/rsyncd.log # 日志文件位置,启动rsync后自动产生这个文件,无需提前创建
path = /var/www/html # rsync服务端数据目录路径
read only = false # 设置rsync服务端文件为读写权限
hosts allow = 192.168.118.15 # 允许进行数据同步的客户端IP地址,可以设置多个,用英文状态下逗号隔开
auth users = rsync # 执行数据同步的用户名,可以设置多个,用英文状态下逗号隔开
secrets file = /etc/rsync.password # 用户认证配置文件,里面保存用户名称和密码,后面会创建这个文件 [root@192.168.118.15 ~]#echo "rsync:123456" > /etc/rsync.password # 用户认证配置文件,里面保存用户名称和密码,后面会创建这个文件
[root@192.168.118.15 ~]#chmod /etc/rsync.password # 配置文件权限,如果这里没修改权限,后续会报错
[root@192.168.118.15 ~]#systemctl start rsyncd ; systemctl enable rsyncd
Created symlink from /etc/systemd/system/multi-user.target.wants/rsyncd.service to /usr/lib/systemd/system/rsyncd.service.

  到此,客户端(同步端)配置完毕。

  server 端配置:

[root@192.168.118.14 ~]#yum install httpd rsync -y

下载 inotify 并编译安装:

下载地址:https://sourceforge.net/projects/inotify-tools/

[root@192.168.118.14 /usr/local/src]#yum install gcc* -y
[root@192.168.118.14 /usr/local/src]#tar xf inotify-tools-3.13.tar.gz
[root@192.168.118.14 /usr/local/src]#cd inotify-tools-3.13
[root@192.168.118.14 /usr/local/src/inotify-tools-3.13]#./configure --prefix=/usr/local/inotify/
[root@192.168.118.14 /usr/local/src/inotify-tools-3.13]#make && make install
[root@192.168.118.14 /usr/local/src/inotify-tools-3.13]#echo "export PATH=$PATH:/usr/local/inotify/bin" > /etc/profile.d/inotify.sh
[root@192.168.118.14 /usr/local/src/inotify-tools-3.13]#. /etc/profile.d/inotify.sh
[root@192.168.118.14 ~]#echo > /etc/server.pass
[root@192.168.118.14 ~]#chmod /etc/server.pass
# 编写同步脚本
[root@192.168.118.14 ~]#vim inotify.sh #!/bin/bash # 同步端的ip
host_slave=192.168.118.15
# 需要同步的目录
master_src=/var/www/html/ /usr/local/inotify/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f' -e close_write,modify,delete,create,attrib /var/www/html/ | while read file
do
rsync -az --delete ${master_src} rsync@${host_slave}::apache --password-file=/etc/server.pass
done

3. 测试

4. 配置过程常见错误

报错1:

ERROR: password file must not be other-accessible
rsync error: syntax or usage error (code ) at authenticate.c() [sender=3.0.]

处理办法:

  检查服务端的  /etc/server.pass 权限是否是 600

[root@localhost html]# chmod  /etc/server.pass
[root@localhost html]# ll /etc/server.pass
-rw-------. root root Apr : /etc/server.pass

报错2:

@ERROR: Unknown module 'apache'
rsync error: error starting client-server protocol (code ) at main.c() [sender=3.0.]

处理办法:

  检查 client端 rsyncd.conf ,[apache] 模块内的配置

rsync + inotify 实时同步的更多相关文章

  1. rsync+inotify实时同步环境部署记录

    随着应用系统规模的不断扩大,对数据的安全性和可靠性也提出的更好的要求,rsync在高端业务系统中也逐渐暴露出了很多不足.首先,rsync在同步数据时,需要扫描所有文件后进行比对,进行差量传输.如果文件 ...

  2. rsync+inotify实时同步方案

    rsync+inotify实时同步,inotify可以实时监控本地文件或目录变化,当检测到本地文件变化,执行rsync同步命令,将变化的文件同步到其他服务器节点. 1.配置环境 3.在服务节点1.服务 ...

  3. CentOS6.5实现rsync+inotify实时同步

    参考博文: 参考1:CentOS6.5实现rsync+inotify实时同步 参考2:inotify-tools+rsync实时同步文件安装和配置 CentOS 6.3下rsync服务器的安装与配置  ...

  4. 配置rsync+inotify实时同步

    与上一篇同步做 配置rsync+inotify实时同步 1:调整inotify内核参数 在linux内核中,默认的inotify机制提供三个调控参数:max_queue_events.max_user ...

  5. linux设置rsync+inotify实时同步文件

    linux设置rsync+inotify实时同步文件   应用场景: 同步接收方:test01 接收目录:/opt/software/test/a/ 同步发起方:test02 同步目录:/opt/so ...

  6. (转)rsync+inotify实时同步

    原文:http://lxw66.blog.51cto.com/5547576/1331048 声明:rsync inotify 需要逆向思考,当只做rsync不实时同步时,我们一般是从rsync服务端 ...

  7. 浅谈Rsync+Inotify实时同步

    Rsync是Unix/Linux旗下的一款应用软件,利用它可以是多台服务器数据保持同步一致性,第一次同步时rsync会复制全部内容,但在下次只传输修改过的文件 Rsync在传输数据的过程中可以实行压缩 ...

  8. rsync+inotify实时同步

    !!!在安装前要先确保,rsync daemon服务配置成功,在安装inotify-tools前先确认你的linux内核是否达到了2.6.13,并且在编译时开启CONFIG_INOTIFY选项,也可以 ...

  9. centos 6 rsync+inotify 实时同步

    主机名.ip: server 172.31.82.184 client  172.31.82.185 需求: 1.server端 ”/data/server“ 做为client端 “/data/cli ...

随机推荐

  1. 【转】每个 Linux 新手都应该知道的 10 个命令

    你可能认为你是 Linux 新手,但实际上并不是.全球互联网用户有 3.74 亿,他们都以某种方式使用 Linux,因为 Linux 服务器占据了互联网的 90%.大多数现代路由器运行 Linux 或 ...

  2. 单点登录(九)-----遇到问题-----FileNotFoundException: class path resource-UsernamePasswordWrapperAuthenticatio

    运行cas server 项目时 报错 FileNotFoundException: class path resource-UsernamePasswordWrapperAuthenticatio ...

  3. 20170520 DP阶段总结

    DP的力量不是无穷的. 但是,因为它叫做“动态规划”,它在OI界如鱼得水.这个“动态”不是指“离线”与“在线”,也不是什么“可持久化”.它只是把问题抽象为一个个“阶段”,在每一个“阶段”中作出或繁或简 ...

  4. [USACO18OPEN]Out of Sorts P 冒泡排序理解之二

    题目描述 Bessie把快速排序和冒泡排序混在了一起 给一个伪快排的代码: 冒泡: bubble_sort_pass (A) { to length(A)- ], swap A[i] and A[i+ ...

  5. Java入门:基础算法之从字符串中找到重复的字符

    本程序演示从一个字符串中找出重复的字符,并显示重复字符的个数. import java.util.HashMap; import java.util.Map; import java.util.Set ...

  6. R语言颜色综合运用与色彩方案共享

    R语言颜色综合运用与色彩方案共享 小魔方 EasyCharts 2016-11-21 今天这篇主要讲解R语言颜色综合运用,主要跟大家介绍如何提取那些专业色彩包中的颜色搭配用于在基础绘图系统和高级绘图系 ...

  7. python的map函数的使用方法详解以及使用案例(处理每个元素的自增、自减、平方等)

    1.用我们之前学过的求一下平方(只有一个列表) #求平方 num=[1,5,6,2,7,8] a=[] for n in num: a.append(n**2) print (a) C:\python ...

  8. Shell记录-Shell脚本基础(四)

    while循环,使您能够重复执行一组命令,直到某些条件发生.它通常用于当你需要反复操纵的变量值. 语法 while command do Statement(s) to be executed if ...

  9. webpack的基础入门

    webpack的基础入门 这里对于 webpack 的基础入门进行一些总结,可以参考 github 上的 webpack-demo ,链接是 https://github.com/RealAndMe/ ...

  10. Postman简明教程

    一.Postman简介 Postman是一款接口测试工具,常用于日常工作的接口类功能测试和简单的自动化测试. 二.Postman功能介绍 1.常见get请求的接口测试 我们现在有这样一个获取学生信息的 ...