RsyncInotify-tools简介
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了RsyncInotify-tools简介相关的知识,希望对你有一定的参考价值。
Rsync简介
rsync,remote synchronize顾名思意就知道它是一款实现远程同步功能的软件,它在同步文件的同时,可以保持原来文件的权限、时间、软硬链接等附加信息。rsync是用 “rsync 算法”提供了一个客户机和远程文件服务器的文件同步的快速方法,而且可以通过ssh方式来传输文件,这样其保密性也非常好,另外它还是免费的软件。
地址:http://rsync.samba.org/ftp/rsync/src/
安装
CentOS系统默认已经安装rsync
[[email protected] ~]# rpm -qa|grep -i rsync rsync-3.0.6-12.el6.x86_64 [[email protected] ~]# rpm -e --nodeps $(rpm -qa|grep -i rsync) [[email protected] ~]# rpm -qa|grep -i rsync [[email protected] ~]# cd /usr/local/src/ [[email protected] src]# tar -zxvf rsync-3.1.2.tar.gz #yum install -y rsync [[email protected] src]# cd rsync-3.1.2 [[email protected] rsync-3.1.2]# ./configure --prefix=/app/rsync [[email protected] rsync-3.1.2]# make && make install
配置
同步目的端需要配置,数据源端无需配置。
[[email protected] rsync-3.1.2]# vim /etc/rsyncd.conf [global] #全局配置 uid = nobody gid = nobody use chroot = no timeout =300 port = 873 max connections = 30 pid file = /var/runn/rsyncd.pid lock file = /var/runn/rsync.lock log file = /var/log/rsyncd.log log format = %t %a %u %m %f %b #日志的格式 %h 远程主机名 %a 远程IP地址 %l 文件长度字符数 %p 该次rsync会话的进程id %o 操作类型:"send"或"recv" %f 文件名 %P 模块路径 %m 模块名 %t 当前时间 %u 认证的用户名(匿名时是null) %b 实际传输的字节数 %c 当发送文件时,该字段记录该文件的校验码 默认log格式为:"%o %h [%a] %m (%u) %f %l",一般来说,在每行的头上会添加"%t [%p] " [app_rsync_server] # 要同步的模块名 path = /app/rsync_server comment = server #这个名名称无所谓 read only = no # no客户端可上传文件,yes只读 write only = no # no客户端可下载文件,yes不能下载 list = no #是否提供资源列表 ignore errors #忽略一些无关的IO错误 hosts allowd = 10.15.43.0/24 #多个IP或网段需要用空格隔开,“*”则表示所有,默认是允许所有主机连接 hosts deny = * auth users = rsync #登陆系统使用的用户名,没有默认为匿名 secrets file = /etc/rsyncd.secret #密码文件存放的位置 [[email protected] rsync-3.1.2]# vim /etc/rsyncd.secret rsync:123456 [[email protected] rsync-3.1.2]# chmod 600 /etc/rsyncd.secret
ignore errors
这个选项最好加上,否则再很多crontab的时候往往发生错误你也未可知,因为你不可能天天去看每时每刻去看log,不加上这个出现错误的几率相对会很高,因为任何大点的项目和系统,磁盘IO都是一个瓶颈。
启动与关闭
daemon方式启动
[[email protected] rsync-3.1.2]# /app/rsync/bin/rsync --daemon --config=/etc/rsyncd.conf [[email protected] rsync-3.1.2]# netstat -anotp|grep :873 tcp 0 0 0.0.0.0:873 0.0.0.0:* LISTEN 9622/rsync off (0.00/0/0) tcp 0 0 :::873 :::* LISTEN 9622/rsync off (0.00/0/0) [[email protected] rsync-3.1.2]# pkill rsync [[email protected] rsync-3.1.2]# netstat -anotp|grep :873 [[email protected] rsync-3.1.2]#
利用xinetd控制rsync启动
[[email protected] rsync-3.1.2]# vim /etc/xinetd.d/rsync # default: off # description: The rsync server is a good addition to an ftp server, as it # allows crc checksumming etc. service rsync { disable = no #将yes改为no flags = IPv6 socket_type = stream wait = no user = root server = /app/rsync/bin/rsync #修改为rsync程序路径 server_args = --daemon log_on_failure += USERID } [[email protected] rsync-3.1.2]# /etc/init.d/xinetd restart
客户端配置和测试
客户端(数据源端)无需配置rsync配置文件/etc/rsyncd.conf,只需要安装并启动rsync和建一个和服务端一样的密码的密码文件
客户端
[[email protected] ~]# yum -y install rsync xinetd [[email protected] ~]# vim /etc/xinetd.d/rsync service rsync { disable = no #修改为no flags = IPv6 socket_type = stream wait = no user = root server = /usr/bin/rsync server_args = --daemon log_on_failure += USERID } [[email protected] ~]# echo 123456 > /etc/rsyncd.secret [[email protected] ~]# chmod 600 /etc/rsyncd.secret [[email protected] rsync_client]# touch file{1..8} [[email protected] rsync_client]# rsync -avH --port=873 --progress --delete /app/rsync_client/ [email protected]::app_rsync_server --password-file=/etc/rsyncd.secret sending incremental file list ./ file1 0 100% 0.00kB/s 0:00:00 (xfer#1, to-check=7/9) file2 0 100% 0.00kB/s 0:00:00 (xfer#2, to-check=6/9) file3 0 100% 0.00kB/s 0:00:00 (xfer#3, to-check=5/9) file4 0 100% 0.00kB/s 0:00:00 (xfer#4, to-check=4/9) file5 0 100% 0.00kB/s 0:00:00 (xfer#5, to-check=3/9) file6 0 100% 0.00kB/s 0:00:00 (xfer#6, to-check=2/9) file7 0 100% 0.00kB/s 0:00:00 (xfer#7, to-check=1/9) file8 0 100% 0.00kB/s 0:00:00 (xfer#8, to-check=0/9) sent 404 bytes received 163 bytes 1134.00 bytes/sec total size is 0 speedup is 0.00 [[email protected] rsync_client]#
Rsync参数:
-v, --verbose 详细模式输出
-q, --quiet 精简输出模式
-c, --checksum 打开校验开关,强制对文件传输进行校验
-a, --archive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等于-rlptgoD
-r, --recursive 对子目录以递归模式处理
-R, --relative 使用相对路径信息
-b, --backup 创建备份,也就是对于目的已经存在有同样的文件名时,将老的文件重新命名为~filename。可以使用--suffix选项来指定不同的备份文件前缀。
--backup-dir 将备份文件(如~filename)存放在在目录下。
-suffix=SUFFIX 定义备份文件前缀
-u, --update 仅仅进行更新,也就是跳过所有已经存在于DST,并且文件时间晚于要备份的文件。(不覆盖更新的文件)
-l, --links 保留软链结
-L, --copy-links 想对待常规文件一样处理软链结
--copy-unsafe-links 仅仅拷贝指向SRC路径目录树以外的链结
--safe-links 忽略指向SRC路径目录树以外的链结
H, --hard-links 保留硬链结
-p, --perms 保持文件权限
-o, --owner 保持文件属主信息
-g, --group 保持文件属组信息
-D, --devices 保持设备文件信息
-t, --times 保持文件时间信息
-S, --sparse 对稀疏文件进行特殊处理以节省DST的空间
-n, --dry-run现实哪些文件将被传输
-W, --whole-file 拷贝文件,不进行增量检测
-x, --one-file-system 不要跨越文件系统边界
-B, --block-size=SIZE 检验算法使用的块尺寸,默认是700字节
-e, --rsh=COMMAND 指定使用rsh、ssh方式进行数据同步
--rsync-path=PATH 指定远程服务器上的rsync命令所在路径信息
-C, --cvs-exclude 使用和CVS一样的方法自动忽略文件,用来排除那些不希望传输的文件
--existing 仅仅更新那些已经存在于DST的文件,而不备份那些新创建的文件
--delete 删除那些DST中SRC没有的文件
--delete-excluded 同样删除接收端那些被该选项指定排除的文件
--exclude-from=文件名 排除文件中指定模式的文件,不传送,一行一个目录,使用相对路径
--delete-after 传输结束以后再删除
--ignore-errors 及时出现IO错误也进行删除
--max-delete=NUM 最多删除NUM个文件
--partial 保留那些因故没有完全传输的文件,以是加快随后的再次传输
--force 强制删除目录,即使不为空
--numeric-ids 不将数字的用户和组ID匹配为用户名和组名
--timeout=TIME IP超时时间,单位为秒
-I, --ignore-times 不跳过那些有同样的时间和长度的文件
--size-only 当决定是否要备份文件时,仅仅察看文件大小而不考虑文件时间
--modify-window=NUM 决定文件是否时间相同时使用的时间戳窗口,默认为0
-T --temp-dir=DIR 在DIR中创建临时文件
--compare-dest=DIR 同样比较DIR中的文件来决定是否需要备份
-P 等同于 --partial
--progress 显示备份过程
-z, --compress 对备份的文件在传输时进行压缩处理
--exclude=PATTERN 指定排除不需要传输的文件模式
--include=PATTERN 指定不排除而需要传输的文件模式
--exclude-from=FILE 排除FILE中指定模式的文件
--include-from=FILE 不排除FILE指定模式匹配的文件
--version 打印版本信息
--address 绑定到特定的地址
--config=FILE 指定其他的配置文件,不使用默认的rsyncd.conf文件
--port=PORT 指定其他的rsync服务端口
--blocking-io 对远程shell使用阻塞IO
-stats 给出某些文件的传输状态
--progress 在传输时现实传输过程
--log-format=formAT 指定日志文件格式
--password-file=FILE 从FILE中得到密码
--bwlimit=KBPS 限制I/O带宽,KBytes per second
-h, --help 显示帮助信息
错误
@ERROR: Unknown module ‘app_rsync_server‘
rsync error: error starting client-server protocol (code 5) at main.c(1503) [sender=3.0.6]
检查/etc/rsyncd.conf文件中hosts allowd项,删除了hosts deny项重启后恢复
inotify简介
Inotify是一种强大的、细粒度的、异步的文件系统事件监控机制,Linux内核从2.6.13起,加入了对Inotify的支持,inotify-tools是用c编写的,除了要求内核支持inotify外,不依赖于其他。inotify-tools提供两种工具,一是inotifywait,它是用来监控文件或目录的变化,二是inotifywatch,它是用来统计文件系统访问的次数。通过Inotify可以监控文件系统中的添加、删除、修改、移动等各种事件.
安装
见CentOS6.8使用Rsync+Inotify-tools实现数据实时同步
配置
Rsync+Inotify-tools实现数据实时同步实现通过脚本来实现
[[email protected] inotify]# cat rsync.sh #!/bin/bash src_dir="/app/rsync_server/" dst_dir="app_rsync_client" exclude_dir="/app/inotify/exclude.list" rsync_user="rsync" rsync_passwd="/etc/passwd.txt" dst_ip="10.15.43.228 10.10.2.84" rsync_command(){ rsync -avH --port=873 --progress --delete --exclude-from=$exclude_dir $src_dir [email protected]$ip::$dst_dir --password-file=$rsync_passwd } for ip in $dst_ip;do rsync_command done /app/inotify/bin/inotifywait -mrq --timefmt ‘%d/%m/%y %H:%M‘ --format ‘%T %w%f%e‘ -e close_write,modify,delete,create,attrib,move $src_dir | while read file;do for ip in $dst_ip;do rsync_command echo "${file} was rsynced" >> /tmp/rsync.log 2>&1 done done [[email protected] inotify]# chmod +x rsync.sh [[email protected] inotify]# touch /app/inotify/exclude.list [[email protected] inotify]# vim /etc/rc.d/rc.local nohup /bin/sh /app/inotify/rsync.sh & [[email protected] inotify]# nohup /bin/sh /app/inotify/rsync.sh &
inotifywait
语法:
inotifywait [-hcmrq] [-e ] [-t ] [--format ] [--timefmt ] [ ... ]
参数:
-h,--help输出帮助信息
@排除不需要监视的文件,可以是相对路径,也可以是绝对路径。
--fromfile 从文件读取需要监视的文件或排除的文件,一个文件一行,排除的文件以@开头。
-m, --monitor保持一直监听,无限期地执行。默认的行为是接收到一个事情后立即退出。
-d, --daemon跟--monitor一样,除了是在后台运行,需要指定--outfile把事情输出到一个文件。也意味着使用了--syslog。
-o, --outfile 输出事情到一个文件而不是标准输出。
-s, --syslog输出错误信息到系统日志
-r, --recursive监视一个目录下的所有子目录。
-q, --quiet指定一次,不会输出详细信息,指定二次,除了致命错误,不会输出任何信息。
--exclude 正则匹配需要排除的文件,大小写敏感。
--excludei 正则匹配需要排除的文件,忽略大小写。
-t , --timeout 设置超时时间,如果为0,则无限期地执行下去。
-e , --event 指定监视的事件。
-c, --csv输出csv格式。
--timefmt 指定时间格式,用于--format选项中的%T格式。
"%”后面的大小写代表不同的格式,如%y表示2位的年,%Y表示4位的年
%y年 %m月 %d日 %H小时 %M分钟 %S 秒
--format 指定输出格式。
%w 表示发生事件的目录
%f 表示发生事件的文件
%e 表示发生的事件
%Xe 事件以“X"分隔
%T 使用由--timefmt定义的时间格式
inotifywatch
语法:
inotifywatch [-hvzrqf] [-e ] [-t ] [-a ] [-d ] [ ... ]
参数:
-h, --help输出帮助信息
-v, --verbose输出详细信息
@排除不需要监视的文件,可以是相对路径,也可以是绝对路径。
--fromfile 从文件读取需要监视的文件或排除的文件,一个文件一行,排除的文件以@开头。
-z, --zero输出表格的行和列,即使元素为空
--exclude 正则匹配需要排除的文件,大小写敏感。
--excludei 正则匹配需要排除的文件,忽略大小写。
-r, --recursive监视一个目录下的所有子目录。
-t , --timeout 设置超时时间
-e , --event 监听指定的事件。
-a , --ascending 以指定事件升序排列。
-d , --descending 以指定事件降序排列。
可监听事件
access文件读取
modify文件更改。
attrib文件属性更改,如权限,时间戳等。
close_write以可写模式打开的文件被关闭,不代表此文件一定已经写入数据。
close_nowrite以只读模式打开的文件被关闭。
close文件被关闭,不管它是如何打开的。
open文件打开。
moved_to一个文件或目录移动到监听的目录,即使是在同一目录内移动,此事件也触发。
moved_from一个文件或目录移出监听的目录,即使是在同一目录内移动,此事件也触发。
move包括moved_to和 moved_from
move_self文件或目录被移除,之后不再监听此文件或目录。
create文件或目录创建
delete文件或目录删除
delete_self文件或目录移除,之后不再监听此文件或目录
unmount文件系统取消挂载,之后不再监听此文件系统。
本文出自 “我本不是菜鸟” 博客,请务必保留此出处http://ityunwei2017.blog.51cto.com/7662323/1952655
以上是关于RsyncInotify-tools简介的主要内容,如果未能解决你的问题,请参考以下文章
Android 逆向Linux 文件权限 ( Linux 权限简介 | 系统权限 | 用户权限 | 匿名用户权限 | 读 | 写 | 执行 | 更改组 | 更改用户 | 粘滞 )(代码片段
SpringCloud系列十一:SpringCloudStream(SpringCloudStream 简介创建消息生产者创建消息消费者自定义消息通道分组与持久化设置 RoutingKey)(代码片段
C#-WebForm-★内置对象简介★Request-获取请求对象Response相应请求对象Session全局变量(私有)Cookie全局变量(私有)Application全局公共变量Vi(代码片段