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