在我们的应用中,会经常性的修改配置文件,但是往往web应用的配置文件是全局性的,如何让修改动态生效?这里提供一种方法。
log4j中我们可以配置log4j.xml动态生效。它是怎么做的?简单的说就是一个daemon线程不停的在检查文件修改时间。
DOMConfigurator.configureAndWatch(String fileName);
如果我们看一下这部分的源代码就会发现:log4j提供了一个抽象类FileWatchdog
这个类完成了线程的大部分工作。然后提供了一个抽象方法doOnChange()给子类来实现。
好了我们的工作其实就变的很简单了。写一个类继承FileWatchdog:
class MyConfigWatchdog extends FileWatchdog {
MyConfigWatchdog(String filename) {
super(filename);
}
/**
* update your configuration object
*/
public void doOnChange() {
//your custom logic
}
}
然后在我们的读配置文件的类里面启动ConfigWatchdog类。
MyConfigWatchdog watchDog = new MyConfigWatchdog(fileName);
watchDog.setDelay(10000); // check configure files change 10 sec
watchDog.start();
这样就可以快速的完成这个小功能。