我的应用场景是重要文件备份

端口:873,备份端打开即可

下载地址:https://rsync.samba.org/ftp/rsync/src/

服务端和客户端要保持版本一致

网盘链接:https://pan.baidu.com/s/1wTsj0cCfXRcREnbzeIviuQ

备份端

1、安装rsync:

...

2、设置密码文件

vim /etc/rsync.pas

cjh:  #格式 用户名:密码   这里的用户名和密码跟系统没有关系的

配置文件

vi /etc/rsyncd.conf  #文件不一定有,可以自己创建

# /etc/rsyncd: configuration file for rsync daemon mode

# See rsyncd.conf man page for more options.

# configuration example:

# uid = nobody
# gid = nobody
# use chroot = yes
# max connections =
# pid file = /var/run/rsyncd.pid
# exclude = lost+found/
# transfer logging = yes
# timeout =
# ignore nonreadable = yes
# dont compress = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2 # [ftp]
# path = /home/ftp
# comment = ftp export area

加上我的配置

uid =root #root是必须的,同步时权限问题
gid =root
use chroot = yes
max connections = 1
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsyncd.lock
log file = /var/log/rsyncd.log
transfer logging = yes
log format = %t %a %m %f %b
timeout =
[test]
read only =no #必须是no
path = /root/ #同步目录路径,要注意同步过来的时候模块名会拼接,比如/root/test/ 这里就只需要填/root/
comment = xxx #可选,无太大作用
auth users =cjh #用户名,注意跟系统的用户密码没关系
secrets file =/etc/rsync.pas #密码文件
hosts allow = ip1,ip2 #源文件端ip

启动

which rsync
/xx/rsync #后台启动
/xx/rsync --daemon ps -ef | grep rsync #看看服务是否正常运行

源文件端

1、安装启动rsync+inotify

注意密码文件格式跟备份端不一样,比如这里直接写123456就可以了,不需要用户名

特别介绍一下就是:rsync有六种不同的工作模式

、rsync [OPTION]... SRC DEST
、rsync [OPTION]... SRC [USER@]HOST:DEST
、rsync [OPTION]... [USER@]HOST:SRC DEST
、rsync [OPTION]... [USER@]HOST::SRC DEST
、rsync [OPTION]... SRC [USER@]HOST::DEST
、rsync [OPTION]... rsync://[USER@]HOST[:PORT]/SRC [DEST]

1)拷贝本地文件。(没用过,不知道效果怎样)

2)使用一个远程shell程序(如rsh、ssh)来实现将本地机器的内容拷贝到远程机器。(如果没有做免密登录,每次都要输密码)

3)使用一个远程shell程序(如rsh、ssh)来实现将远程机器的内容拷贝到本地机器。(如果没有做免密登录,每次都要输密码)

4)从远程rsync服务器中拷贝文件到本地机。(定期备份可以用这个)

5)从本地机器拷贝文件到远程rsync服务器中。(实时备份用这个)

6)列远程机的文件列表。(没用过)

2、一次性同步测试

rsync -av /root/test/ cjh@备份端IP::test --password-file=/etc/rsync.pas --bwlimit=

test是客户端定义的模块,/root/test2 是客户端的目录,密码文件跟服务端不同的是只需要填密码,--bwlimit是网速的限制,--delete是完全同步目录文件

实时同步

安装inotify-tools,下载的网站打不开,我就直接用yum方式安装

yum install -y inotify-tools

实时同步脚本(attrib指文件的属性,比如只读)

#!/bin/bash
host1=IP #备份服务器IP
src=/root/test/ #同步目录最好保持一致
dst1=test #模块名称
user1=cjh #用户名
/usr/local/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f%e' -e create,modify,attrib $src \
| while read files
do
rsync -av $src $user1@$host1::$dst1 --password-file=/etc/rsync.pas --bwlimit=
echo "${files} was rsynced."
done

启动脚本

nohup sh run.sh  > run.out & >& &

测试通过

注意点:

1、chmod 600 /etc/rsync.pas,两端都需要做这个操作

2、大文件的同步是很慢的,同步的时候卡住注意是不是文件太大了

3、上线前认真做好测试和普通方式的备份,以及尽量不要使用--delete,防止数据丢失

4、/etc/rsyncd.conf配置文件中一个注释都不能写,上面只是为了方便表达参数含义!

5、当文件数量超多的时候,同步会有一点延迟,大概是几分钟

转载请注明博客出处:http://www.cnblogs.com/cjh-notes/

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

  1. 文件实时同步(rsync+inotify)

    目标服务器:10.11.6.11 源服务器:10.11.6.12 准备条件: 1.关闭selinux: vi /etc/selinux/config #编辑防火墙配置文件 #SELINUX=enfor ...

  2. 实时同步inotify+rsync

    目的,要求 nfs储存服务器与backup备份服务器,数据同步,万一nfs储存服务器挂了,数据还在 实时同步备份软件服务 1)inotify 实时同步软件 2)sersync 实时同步软件 实时同步原 ...

  3. CentOs文件实时同步

    1,生成数据序

  4. Centos 6.5 rsync+inotify 两台服务器文件实时同步

    rsync和inotify是什么我这里就不在介绍了,有专门的文章介绍这两个工具. 1.两台服务器IP地址分别为: 源服务器:192.168.1.2 目标服务器:192.168.1.3 @todo:从源 ...

  5. rsync+inotify 实现服务器之间目录文件实时同步(转)

    软件简介: 1.rsync 与传统的 cp. tar 备份方式相比,rsync 具有安全性高.备份迅速.支持增量备份等优点,通过 rsync 可 以解决对实时性要求不高的数据备份需求,例如定期的备份文 ...

  6. inotify用法简介及结合rsync实现主机间的文件实时同步

    一.inotify简介 inotify是Linux内核2.6.13 (June 18, 2005)版本新增的一个子系统(API),它提供了一种监控文件系统(基于inode的)事件的机制,可以监控文件系 ...

  7. (转)Linux下通过rsync与inotify(异步文件系统事件监控机制)实现文件实时同步

    Linux下通过rsync与inotify(异步文件系统事件监控机制)实现文件实时同步原文:http://www.summerspacestation.com/linux%E4%B8%8B%E9%80 ...

  8. rsync+inotify百万级文件实时同步

    实验环境:Centos7.4 目的:将源服务器的文件实时同步至目标服务器 源服务器:10.11.1.107 目标服务器:10.11.1.106 分别在两个节点安装rsync yum -y instal ...

  9. rsync+sersync实现数据文件实时同步

    一.简介 sersync是基于Inotify开发的,类似于Inotify-tools的工具: sersync可以记录下被监听目录中发生变化的(包括增加.删除.修改)具体某一个文件或某一个目录的名字: ...

随机推荐

  1. 原生javascript的意义

    原生JS是指遵循ECMAscript标准的javascript,不同于微软的jscript也不依赖于任何框架,依托于浏览器标准引擎的脚本语言. jquery是在原生态的js上集成的框架资源,使用jqu ...

  2. unicode 和utf-8,GBK编码

    说到编码,得先从ASCII编码讲起.ASCII编码是由美国人发明,美国的字符不超过255个,所以ASCII编码使用了8bit 即一个字节来存储字符.由于汉字的数量远超255个,所以中国自己发明了一个G ...

  3. NFS pv部署

    一.部署nfs服务端: 可以选择kubernetes_cluster内的任意的node去做为nfs服务端,部署节点也可以.我选择的是部署节点去做为nfs服务端. (1)部署节点安装nfs服务软件包: ...

  4. 标准C语言(7)

    函数调用过程中通常伴随着两个函数之间的数据传递.数据传递存在两个完全相反的方向(可以从调用函数,向被调用函数传递数据也可以从被调用函数向,调用函数传递数据),任意方向的数据传递都使用被调用函数提供的存 ...

  5. java同步锁实现方法

    1.synchronized关键字修饰 当用此关键字修饰方法时,     内置锁会保护整个方法.在调用该方法前,需要获得内置锁,否则就处于阻塞状态 synchronized关键字也可以修饰静态方法,此 ...

  6. 958. Check Completeness of a Binary Tree

    题目来源 题目来源 C++代码实现 /** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode ...

  7. Mongodb的聚合和管道

    MongoDB 聚合 MongoDB中聚合(aggregate)主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果. aggregate() 方法 MongoDB中聚合的方法使用agg ...

  8. 后端返回图片的url,将其转成base64,再次进行上传

      //将图片变成base64再上传(主要是转化来自客户端的图片)  getUrlBase64=(url, ext)=> {     var canvas = document.createEl ...

  9. [人物存档]【AI少女】【捏脸数据】1224今日份的推荐

    点击下载(城通网盘):AISChaF_20191111222714074.png 点击下载(城通网盘):AISChaF_20191108141610951.png

  10. C# IIS域名绑定

    C#解决IIS域名批量绑定: https://shiyousan.com/post/636022975388168065 C#程序控制IIS 添加站点域名绑定: https://blog.csdn.n ...