第1章 为什么需要实时同步
1.实时同步的应用场景
1.解决NFS单点故障问题
2.备份NFS数据并且提供冗余的服务功能
2.实时同步实施的难点
1.什么条件才同步?
2.同步哪些文件?
3.多久同步一次?
4.用什么工具同步?
第2章 inotify实现同步-了解即可
1.inotify简介
Inotify是一种强大的,细粒度的,异步的文件系统事件监视机制
Linux2.6.13起加入了inotify支持,通过inotify可以监控文件系统中添加,删除,修改,移动等各种事件
利用这个内核接口,第三方软件就可以监控文件系统下文件的各种变化情况
而inotify-tools正是实施这样监控的软件
2.inotify实战
2.1 查看当前系统是否支持inotify
#1.查看命令
[root@nfs-31 /data]# uname -r
3.10.0-1160.el7.x86_64
[root@nfs-31 /data]# ll /proc/sys/fs/inotify/
total 0
-rw-r--r-- 1 root root 0 Jun 1 19:48 max_queued_events
-rw-r--r-- 1 root root 0 Jun 1 19:48 max_user_instances
-rw-r--r-- 1 root root 0 Jun 1 19:48 max_user_watches#2.状态解释
max_queued_events 设置inotify实例事件(event)队列可容纳的事件数量
max_user_instances 设置每个用户可以运行的inotify或者inotifywatch命令的进程数
max_user_watches 设置inotifywait或者inotifywatch命令可以监视的文件数量 (单进程)
2.2 安装iontify-tools
[root@nfs-31 ~]# yum install inotify-tools -y
2.3 inotifywait命令参数解释
[root@nfs-31 ~]# inotifywait --help
inotifywait参数说明
参数名称 参数说明
-m ,-monitor 始终保持事件监听状态
-r,-recursive 递归查询目录
-q,-quiet 只打印监控事件的信息
-exclude 排除文件或目录时,不区分大小写
-t,-timeout 超时时间
--timefmt 指定时间输出格式
--format 指定输出格式
-e,event 后面指定增,删,改等事件
inotifywait events 事件说明
access 读取文件或目录内容
modify 修改文件或目录内容
attrib 文件或目录的属性改变
close 文件被关闭
open