修改配置文件动态生效

 在我们的应用中,会经常性的修改配置文件,但是往往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();

 

这样就可以快速的完成这个小功能。

你可能感兴趣的:(log4j)