1. 程式人生 > >log4j不打日誌問題之實戰解決方案(二)

log4j不打日誌問題之實戰解決方案(二)

最近在tomcat 容器下啟動專案的時候,接二連三的發現有些專案間歇性的不會列印日誌,由於負責多個專案,多數專案會列印日誌,所以沒注意這個問題。就在昨天有一個專案部署上線的時候,在生產環境下,tomcat啟動正常,但是沒有列印任何日誌資訊,於是才開始留意這個問題。經過仔細的排查,才找到問題的根源。

問題的根源:

log4j在web.xml裡面配置如下:

<!-- log4jConfigLocation:log4j配置檔案存放路徑 -->
<context-param>
    <param-name>log4jConfigLocation</param-name
>
<param-value>classpath:log4j.properties</param-value> </context-param> <listener> <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class> </listener>

在啟動的時候,tomcat會列印三行warn級別的日誌:

log4j:WARN No appenders could be found for
logger (org.apache.commons.httpclient.params.DefaultHttpParams). log4j:WARN Please initialize the log4j system properly. log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.

這是由於在classpath下未找到log4j.properties檔案,很奇怪,在classpath的確配置了log4j.properties。
後來在web.xml路徑改為/WEB-INF/classes/log4j.properties

才得以解決。