一.rsync+inotify主服务器部署

1.1安装rsync

[root@nginx ~]# cd /usr/src/

[root@nginx src]# tar zxvf rsync-3.0.9.tar.gz

[root@nginx src]# cd rsync-3.0.9

[root@nginx rsync-3.0.9]# ./configure --prefix=/usr/local/rsync

[root@nginx rsync-3.0.9]# make

[root@nginx rsync-3.0.9]# make install

1.2创建密码认证文件

[root@nginx rsync-3.0.9]# cd /usr/local/rsync/

[root@nginx rsync]# echo "123456" >/etc/rsync.pass

请记住,在server端建立的密码文件,只有密码,没有用户名;而在备份服务端client里建立的密码文件,用户名与密码都有

[root@nginx rsync]# chmod 600 /etc/rsync.pass

1.3安装inotify

[root@nginx rsync]# cd /usr/src/

[root@nginx src]# tar zxvf inotify-tools-3.14.tar.gz

[root@nginx src]# cd inotify-tools-3.14

[root@nginx inotify-tools-3.14]# ./configure --prefix=/usr/local/inotify

[root@nginx inotify-tools-3.14]# make

[root@nginx inotify-tools-3.14]# make install

1.4环境变量配置

echo "PATH=/usr/local/inotify/bin:$PATH" >>/etc/profile.d/inotify.sh

source /etc/profile.d/inotify.sh  #使设置立即生效

echo "/usr/local/inotify/lib" >/etc/ld.so.conf.d/inotify.conf

ln -s /usr/local/inotify/include  /usr/include/inotify

修改系统默认参数:

查看系统默认参数值

sysctl -a | grep max_queued_events

结果是:fs.inotify.max_queued_events = 16384

sysctl -a | grep max_user_watches

结果是:fs.inotify.max_user_watches = 8192

sysctl -a | grep max_user_instances

结果是:fs.inotify.max_user_instances = 128

修改参数:

sysctl -w fs.inotify.max_queued_events="99999999"

sysctl -w fs.inotify.max_user_watches="99999999"

sysctl -w fs.inotify.max_user_instances="65535"

vi /etc/sysctl.conf #添加以下代码

fs.inotify.max_queued_events=99999999

fs.inotify.max_user_watches=99999999

fs.inotify.max_user_instances=65535

:wq! #保存退出

1.5关闭防火墙

vi /etc/selinux/config #编辑防火墙配置文件

#SELINUX=enforcing #注释掉

#SELINUXTYPE=targeted #注释掉

SELINUX=disabled #增加

:wq! #保存,退出

setenforce 0  #立即生效

1.6开启rsync

Rsync –daemon

1.7创建实时出发rsync.sh脚本

vi /usr/local/inotify/rsync.sh   #编辑,添加以下代码

#!/bin/sh

srcdir=/var/atliassian/    //我们要同步的文件夹绝对路径

dstdir=n2  //从服务器rsync配置文件中自定义名称

excludedir=/usr/local/inotify/exclude.list //不同步的文件夹

rsyncuser=n2_user  //从服务器rsync配置文件中的auth user选项一致

rsyncpassdir=/etc/rsync_pass

dstip="192.168.139.129 " //从服务器IP,可以是多个,用逗号隔开

for ip in $dstip

do

rsync -avH --port=873 --progress --delete  --exclude-from=$excludedir  $srcdir $rsyncuser@$ip::$dstdir --password-file=$rsyncpassdir

done

/usr/local/inotify/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f%e' -e close_write,modify,delete,create,attrib,move $srcdir |  while read file

do

for ip in $dstip

do

rsync -avH --port=873 --progress --delete  --exclude-from=$excludedir  $srcdir $rsyncuser@$ip::$dstdir --password-file=$rsyncpassdir

echo "  ${file} was rsynced" >> /tmp/rsync.log 2>&1

done

done

1.8设置rsync.sh开机自启动

vi /etc/rc.d/rc.local  #编辑,在最后添加一行

sh /usr/local/inotify/rsync.sh & #设置开机自动在后台运行脚本

:wq!  #保存退出

二.从服务器部署rsync

2.1关闭selinux

vi /etc/selinux/config #编辑防火墙配置文件

#SELINUX=enforcing #注释掉

#SELINUXTYPE=targeted #注释掉

SELINUX=disabled #增加

:wq! #保存,退出

setenforce 0  #立即生效

开启防火墙tcp 873端口(Rsync默认端口)

vi /etc/sysconfig/iptables #编辑防火墙配置文件

-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 873 -j ACCEPT

:wq! #保存,退出

/etc/init.d/iptables restart #最后重启防火墙使配置生效

注:可以直接关闭防火墙 iptables -F

2.2安装rsync软件

[root@nginx ~]# cd /usr/src/

[root@nginx src]# tar zxvf rsync-3.0.9.tar.gz

[root@nginx src]# cd rsync-3.0.9

[root@nginx rsync-3.0.9]# ./configure --prefix=/usr/local/rsync

[root@nginx rsync-3.0.9]# make

[root@nginx rsync-3.0.9]# make install

2.3配置rsync文件

vim /etc/rsyncd.conf #创建配置文件,添加以下代码

uid = root      #设置rsync运行权限为root

gid = root      #设置rsync运行权限为root

port=873  #默认端口

use chroot = no    #默认为true,修改为no,增加对目录文件软连接的备份

max connections = 40  #最大连接数

timeout = 300       #设置超时时间

pid file = /var/run/rsyncd.pid     #pid文件的存放位置

lock file = /var/run/rsync.lock     #支持max connections参数的锁文件

log file = /var/log/rsyncd.log #日志文件位置启动rsync后自动产生这个文件,无需提前创建

secrets file =/etc/rsync.pass #用户认证配置文件,里面保存用户名称和密码

modtd file=/etc/rsyncd.Motd  #rsync启动时欢迎信息页面文件位置(文件内容自定义)

[n2] #自定义名称

path = /var/atliassian / #rsync服务端数据目录路径

comment=n2 #模块名称与[n2]自定义名称相同

ignore errors

read only = no      #设置rsync服务端文件为读写权限

list = no  #不显示rsync服务端资源列表

hosts allow = 主服务器IP   #允许进行数据同步的客户端IP地址,可以设置多个

auth users = n2_user #执行数据同步的用户名,可以设置多个,逗号隔开,与密码认证文件的用户名一致

#hosts deny = 192.168.21.254 #禁止数据同步的客户端IP地址,可以设置多个

2.4创建密码认证文件

vim /etc/rsync.pass

n2_user:123456  //格式用户名:密码  密码要与服务端rsync.pass密码保持一致

//n2_user 是从服务器rsyncd.conf配置文件中的auth user的值

2.5赋予密码认证文件权限

chmod 600 /etc/rsync.pass

chmod 600 /etc/rsyncd.conf

2.6开启rsync

rsync –daemon

rsync+inotify磁盘数据实时同步的更多相关文章

  1. CentOS 6.5 rsync+inotify实现数据实时同步备份

    CentOS 6.5 rsync+inotify实现数据实时同步备份 rsync    remote sync 远程同步,同步是把数据从缓冲区同步到磁盘上去的.数据在内存缓存区完成之后还没有写入到磁盘 ...

  2. sersync基于rsync+inotify实现数据实时同步

    一.环境描述 需求:服务器A与服务器B为主备服务模式,需要保持文件一致性,现采用sersync基于rsync+inotify实现数据实时同步 主服务器A:192.168.1.23 从服务器B:192. ...

  3. 实战:rsync+inotify实现数据实时同步

    Linux 内核从 2.6.13 版本开始提供了 inotify 通知接口,用来监控文件系统的各种变化情况,如文件存取.删除.移动等.利用这一机制,可以非常方便地实现文件异动告警.增量备份,并针对目录 ...

  4. rsync+inotify实现数据实时同步

    rsync rsync是linux系统下的数据镜像备份工具.支持远程同步,本地复制,或者与其他SSH.rsync主机同步. 优点: 1).可以镜像保存整个目录树和文件系统.保存源目录整个目录树和文件系 ...

  5. 利用rsync+inotify实现数据实时同步脚本文件

    将代码放在Server端,实现其它web服务器同步.首先创建rsync.shell,rsync.shell代码如下: #!/bin/bash host1=133.96.7.100 host2=133. ...

  6. 通过rsync+inotify实现数据实时备份同步

    一.环境描述 测试环境 需求:服务器A与服务器B为主备服务模式,需要保持文件一致性,现采用sersync基于rsync+inotify实现数据实时同步 环境描述: 主服务器172.26.7.50 ,从 ...

  7. Linux下Rsync+sersync实现数据实时同步

    inotify 的同步备份机制有着缺点,于是看了sersync同步,弥补了rsync的缺点.以下转自:http://www.osyunwei.com/archives/7447.html 前言: 一. ...

  8. Rsync+sersync实现数据实时同步

    前言: 一.为什么要用Rsync+sersync架构? 1.sersync是基于Inotify开发的,类似于Inotify-tools的工具 2.sersync可以记录下被监听目录中发生变化的(包括增 ...

  9. Linux下Rsync+Inotify-tools实现数据实时同步

    Linux下Rsync+Inotify-tools实现数据实时同步 注意:下面的三个案例都是rsync 每次都是全量的同步(这就坑爹了),而且 file列表是循环形式触发rsync ,等于有10个文件 ...

随机推荐

  1. nowcoder 211E - 位运算?位运算! - [二进制线段树][与或线段树]

    题目链接:https://www.nowcoder.com/acm/contest/211/E 题目描述 请实现一个数据结构支持以下操作:区间循环左右移,区间与,区间或,区间求和. 输入描述: 第一行 ...

  2. tensorflow一些常用函数的使用注意

    tf.abs() 求tensor中数据的绝对值 tf.sign() 每一个数据都执行sigmod函数,得到对应的数值 tf.reduce_sum() 对不同维度数据求和.注意:1:求和每一行 0:求和 ...

  3. CSS3 transform 属性

    CSS3 transform 属性 语法: transform: none|transform-functions; 值 描述 none 定义不进行转换. matrix(n,n,n,n,n,n) 定义 ...

  4. SPOJ - TSUM 母函数+FFT+容斥

    题意:n个数,任取三个加起来,问每个可能的结果的方案数. 题解:构造母函数ABC,比如现在有 1 2 3 三个数.则 其中B表示同一个数加两次,C表示用三次.然后考虑去重. A^3表示可重复地拿三个. ...

  5. hbase本地模式-安装及基本测试

    解压缩hbase二进制安装文件到/opt目录下: #tar -zxvf hbase-0.98.6-cdh5.3.6.tar.gz -C /opt/cdh-5.3.6/ 编辑配置文件,这里仅配置数据目录 ...

  6. 关于Java程序流程控制的整理(已完善)

  7. [daily][archlinux][rsync] rsync

    科普文档:https://wiki.archlinux.org/index.php/Rsync 之前改文件系统时,用过. 然而用的不太对,导致一部分文件的权限出了问题. [troubleshoot][ ...

  8. 如何解决selenium打开chrome提示chromedriver.exe已停止工作

    场景:启动Chrome,打开URL,提示“disconnected: unable to connect to renderer” 解决方法:chromedriver与chrome的对应关系表, 需要 ...

  9. MyBatis的生命周期

    MyBatis的生命周期 所谓的生命周期就是第一个对象应该存活的时间,比如一些对象一次用完后就要关闭,使它们被Java虚拟机(JVM)销毁,以避免继续占用资源,所以我们会根据每一个组件的作用去确定其生 ...

  10. Magento 2数据库EAV模型结构

     EAV模型是一种数据模型 ,用于描述实体的数量预计会很大,但事实上,实体中要使用的属性数量并不多. Magento 2这么设计是为了灵活性,在不影响主干的基础上,任意新增删除属性. EAV模型(E ...