Java使用WatchService监控文件内容变化的示例

网友投稿 335 2023-03-24


Java使用WatchService监控文件内容变化的示例

场景

系统实现中经常需要能够感知配置文件的变化,然后及时更新上下文。

实现方案

自己起一个单独线程,定时加载文件,实现较简单,但是无法保证能够实时捕捉文件变化,同时耗CPU

使用commons-io中的 FileAlterationObserver,思想和上面类似,对比前后文件列表的变化,触发对应事件

JDK 1.7提供的WatchService,利用底层文件系统提供的功能

使用 WatchService

WatchService用来监控一个目录是否发生改变,但是可以通过 WatchEvent 上下文定位具体文件的变化。具体使用过程中要注意以下两点:

文件改变可能会触发两次事件(我的理解:文件内容的变更,元数据的变更),可以通过文件的时间戳来控制

在文件变化事件发生后,如果立即读取文件,可能所获内容并不完整,建议的做法判断文件的 length > 0

// 监控文件的变化,重新加载

executor.submit(new Runnable() {

@Override

public void run() {

try {

final Path path = FileSystems.getDefault().getPath(getMonitorDir());

System.out.println(path);

final WatchService watchService = FileSystems.getDefault().newWatchService();

final WatchKey watchKey = path.register(watchService, StandardWatchEventKinds.ENTRY_MODIFY);

while (true) {

final WatchKey wk = watchService.take();

for (WatchEvent> event : wk.pollEvents()) {

http:// final Path changed = (Path) event.context();

Path absolute = path.resolve(changed);

File configFile = absolute.toFile();

long lastModified = configFile.lastModified();

logger.info(lastModified + "----------------");

// 利用文件时间戳,防止触发两次

if (changed.endsWith(getLicenseName()) && lastModified != LAST_MOD && configFile.length > 0) {

logbNFqlVger.info("----------------- reloading -----------------");

LAST_MOD = lastModified; // 保存上一次时间戳

UPDATED = true; // 设置标志位

}

}

if (UPDATED) {

reloadFile(); // 重新加载

}

// reset the key

boolean valid = wk.reset();

if (!valid) {

logger.error("watch key invalid!");

}

}

} catch (Exception e) {

logger.error("");

}

}

});

参考

Watching a Directory for Changes


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java多线程之死锁的出现和解决方法
下一篇:详解webpack性能优化——DLL
相关文章

 发表评论

暂时没有评论,来抢沙发吧~