Java WatchService基于系统原生事件机制(如inotify)高效监听文件变化,需按获取FileSystem、创建服务、注册路径、循环处理WatchKey流程使用;注册路径须存在且仅监听直接子项,多级需递归注册;须调用key.reset()并用try-with-resources确保关闭,避免资源泄漏与事件丢失。
Java中通过WatchService监听文件变化,核心是利用操作系统底层的文件系统事件通知机制(如Linux的inotify、Windows的ReadDirectoryChangesW),而非轮询,因此高效且低开销。
监听需按固定步骤:获取FileSystem → 创建WatchService → 注册路径并指定监听事件类型 → 启动循环等待并处理WatchKey。
Path对象,且该路径需存在(不能监听不存在的目录)ENTRY_CREATE、ENTRY_MODIFY、ENTRY_DELETE;注意ENTRY_MODIFY在不同系统行为有差异(例如文本文件保存可能触发多次)WatchKey被消费后需调用key.reset(),否则后续事件不会再次入队WatchService默认只监听注册路径的**直接子项**,不递归。若需监听整个目录树,需手动遍历子目录并逐个注册,或借助第三方库(如Apache Commons IO的FileAlterationObs)。
erver
Files.walkFileTree()配合SimpleFileVisitor递归注册WatchService本身不是线程安全的,且其内部依赖本地资源,必须显式关闭。
close()被调用ExecutorService做事件分发OVERFLOW事件说明事件丢失,需结合业务做补偿(如全量比对或日志告警)原生WatchService功能基础,实际项目中易遇兼容性或稳定性问题:
CREATE+DELETE而非MODIFY
基本上就这些。WatchService不复杂但容易忽略重置key和资源释放,上线前务必在目标环境实测事件覆盖度。