rsync+inotify实时同步

简介: rsync+inotify实时同步

Inotify是一种强大的、细粒度的、异步的文件系统事件监控机制,linux内核从2.6.13起,加入了Inotify支持,通过Inotify可以监控文件系统中添加、删除,修改、移动等各种细微事件

资源准备

两台centos7.2机器

一台rsync服务端(192.168.180.234)

服务端配置

uid = root
 gid = root
 use chroot = no
 max connections = 4
 pid file = /var/run/rsyncd.pid
 log file = /var/log/rsyncd.log
# exclude = lost+found/
# dont compress   = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2
# [ftp]
#        path = /home/ftp
#        comment = ftp export area
#
[nfs]
                path = /app/im_test  
                secrets file = /etc/sery.pass
                read only = false #不能只读 要读写

一台rsync客户端

客户端 操作

systemctl stop firewalld
setenforce 0
getenforce 
systemctl disable firewalld

安装inotify

链接:https://pan.baidu.com/s/1GCfDyw3_H7T0GfuWbdgeLw

提取码:kqx6

tar -zxf inotify-tools-3.13.tar.gz
./configure 
 make check
 make 
 make install
 cd /usr/local/inotify/bin
ll

其中 inotifywait 等待文件发生变化,是inotify核心命令

inotifywatch 用于收集文件系统的统计数据,例如发生了多少次inotify事件,某文件被访问了多少次等等,一般用不上

参数介绍

-m  :表示始终监控,否则应该是监控到了一次就退出监控了
-r  :递归监控,监控目录中的任何文件,包括子目录。递归监控可能会超出max_user_watches的值,需要适当调整该值
@<file>  :如果是对目录进行递归监控,则该选项用于排除递归目录中不被监控的文件。file是相对路径还是绝对路径由监控目录是相对还是绝对来决定
-q  :--quiet的意思,静默监控,这样就不会输出一些无关的信息
-e  :指定监控的事件。一般监控的就 delete、create、attrib、modify、close_write
--exclude <pattern>  :通过模式匹配来指定不被监控的文件,区分大小写
--excludei <pattern> :通过模式匹配来指定不被监控的文件,不区分大小写
--timefmt  :监控到事件触发后,输出的时间格式,可指定可不指定该选项,一般设置为[--timefmt '%Y/%m/%d %H:%M:%S']
--format   :用户自定义的输出格式,如[--format '%w%f %e%T']
  %w  :产生事件的监控路径,不一定就是发生事件的具体文件,例如递归监控一个目录,该目录下的某文件产生事件,将输出该目录而非其内具体的文件
  %f  :如果监控的是一个目录,则输出产生事件的具体文件名。其他所有情况都输出空字符串
  %e  :产生的事件名称
  %T  :以"--timefmt"定义的时间格式输出当前时间,要求同时定义"--timefmt"

inotifywait -e 指定监控事件

access :文件被访问

modify :文件被写入,内容被修改

attrib :元数据被修改。包括权限、时间戳、扩展属性等等

close_write :打开的文件被关闭,是为了写文件而打开文件,之后被关闭的事件

close_nowrite :read only模式下文件被关闭,即只能是为了读取而打开文件,读取结束后关闭文件的事件

close :是close_write和close_nowrite的结合,无论是何种方式打开文件,只要关闭都属于该事件

open :文件被打开

moved_to :向监控目录下移入了文件或目录,也可以是监控目录内部的移动

moved_from :将监控目录下文件或目录移动到其他地方,也可以是在监控目录内部的移动

move :是moved_to和moved_from的结合

moved_self :被监控的文件或目录发生了移动,移动结束后将不再监控此文件或目录

create :在被监控的目录中创建了文件或目录

delete :删除了被监控目录中的某文件或目录

delete_self :被监控的文件或目录被删除,删除之后不再监控此文件或目录

umount :挂载在被监控目录上的文件系统被umount,umount后不再监控此目录

isdir :监控目录相关操作

测试监控

[root@180-241 bin]# /usr/local/inotify/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f' -e create,delete,close_write /app/im_test/
10/01/20 18:27 /app/im_test/inotify_new.sh
10/01/20 18:27 /app/im_test/inotify_new.sh

以上是监控的多个时间,可以单独监控某一事件

脚本书写

结果测试

完成

相关文章
|
算法 数据可视化 数据挖掘
决策树算法和实际应用
决策树算法和实际应用
469 2
|
4月前
|
机器学习/深度学习 人工智能 监控
AI 基础知识从0.1到0.2——用“房价预测”入门机器学习全流程
本系列文章深入讲解了从Seq2Seq、RNN到Transformer,再到GPT模型的关键技术原理与实现细节,帮助读者全面掌握Transformer及其在NLP中的应用。同时,通过一个房价预测的完整案例,介绍了算法工程师如何利用数据训练模型并解决实际问题,涵盖需求分析、数据收集、模型训练与部署等全流程。文章适合初学者和开发者学习AI基础与实战技能。
599 25
AI 基础知识从0.1到0.2——用“房价预测”入门机器学习全流程
|
9月前
|
弹性计算 人工智能 运维
你好,操作系统控制台
阿里云操作系统控制台是一款专为运维工程师设计的新工具,支持CentOS 7.6+、Alibaba Cloud Linux 2/3。它通过安装管控组件(agent)实现对服务器的集中监控和管理,简化了传统分散工具链的使用,显著提升了故障定位和性能优化效率。核心功能包括系统概览、健康评分、系统诊断、进程热点追踪及OS Copilot智能助手,帮助用户快速识别和解决性能瓶颈,降低人力成本并提高资源利用率。尤其在混合云环境中,该工具可大幅减少故障排查时间,提升系统稳定性。
202 1
|
机器学习/深度学习 人工智能 Serverless
【深度学习】神经网络中的激活函数:释放非线性的力量
【深度学习】神经网络中的激活函数:释放非线性的力量
624 1
|
机器学习/深度学习 人工智能 算法框架/工具
基于人体姿势估计的舞蹈检测(AI Dance based on Human Pose Estimation)
基于人体姿势估计的舞蹈检测(AI Dance based on Human Pose Estimation)
348 0
|
SQL 关系型数据库 MySQL
PowerDesigner16.5逆向工程导入
本文介绍了如何通过现有数据库或SQL将数据逆向导入PowerDesigner。首先,需下载并安装PowerDesigner 16.5(32位),并通过指定链接获取软件及教程。接着,安装对应的MySQL ODBC驱动,配置ODBC数据源。最后,在PowerDesigner中通过文件&gt;反向工程&gt;database选项导入数据库。若环境不匹配,可直接导入SQL脚本文件。文中提供了详细步骤与截图指导。
557 0
|
监控 测试技术 持续交付
阿里云云效产品使用问题之如何将一个流水线复制到另一个账户下
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。
|
监控 Java Spring
Spring Boot中的热部署配置
Spring Boot中的热部署配置
|
人工智能 安全
我国AIGC的监管态势
【1月更文挑战第21天】我国AIGC的监管态势
295 4
我国AIGC的监管态势
|
消息中间件 Java Kafka
Kafka 生产者 API 指南:深入理解生产者的实现与最佳实践
Kafka 是一个高性能、分布式的消息中间件系统,而其生产者 API 是连接应用程序与 Kafka 集群之间的纽带。本篇博客将深入探讨 Kafka 生产者 API 的核心概念、用法,以及一些最佳实践,帮助你更好地利用 Kafka 构建可靠的消息生产系统。