log4j配置文件中的变量
生活随笔
收集整理的這篇文章主要介紹了
log4j配置文件中的变量
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
我們做log4j配置的時候,經常會使用到這樣的變量${log.dir}或者${log.home},這個變量的值來自系統屬性,就是通過System.setProperty("log.home","log.home")來設置的。而且System.setProperty()方法調用需要在系統啟動的過程中在聲明private static final Logger log = Logger.getLogger(App.class)之前。
如果是web項目,我們可以在web.xml文件中配置一個listener,在這個listener之中,我們設置log.home。
<listener><listener-class>com.xxx.listener.Log4jConfigListener</listener-class> </listener>Log4jConfigListener.java
package com.xxx.listener; import javax.servlet.ServletContextEvent; import javax.servlet.ServletContextListener; public class Log4jConfigListener implements ServletContextListener {@Overridepublic void contextInitialized(ServletContextEvent sce) {System.setProperty("log.dir", "D:/log");}@Overridepublic void contextDestroyed(ServletContextEvent sce) {} }這樣,我們在log4j.properties或者log4j.xml配置文件中指定的變量${log.dir}就會被解析了。
如果不是web項目,在啟動類中,我們可以利用static靜態代碼塊來設置log.dir系統屬性。如下所示:
package com.xxx.log4j.test; import java.util.Random; import org.apache.log4j.Logger; public class Hello {static{System.setProperty("log.dir", "D:/log");} private static final Logger log = Logger.getLogger(Hello.class);public static void main(String[] args) { String str = "this is a log4j test string @ "+new Random().nextInt();log.info(str);} }這樣我們的變量${log.dir}就能被解析,其他的變量類似。
另外,也可以在啟動web容器或者主程序的時候,通過-Dlog.dir=D:/log來指定系統屬性。總之,系統屬性需要設置在Logger聲明之前。一般根據需要合理設置。?
總結
以上是生活随笔為你收集整理的log4j配置文件中的变量的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【算法动画图解-5数学】:(1)辗转相除
- 下一篇: 《WF本质论》第一章OpenSesame