天天看點

SpringMvc配置Log4j日志

配置log4j日志,首先導入 slf4j-log4j12-1.7.7.jar

在maven中配置

<dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>1.7.7</version>
        </dependency>
           
當使用properties檔案配置時
### set log levels ###
log4j.rootLogger = debug,D,E

log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = ${webapp.root}/logs/common-default.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = INFO
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.File =${webapp.root}/logs/error.log
log4j.appender.E.Append = true
log4j.appender.E.Threshold = ERROR
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
           

此時web.xml檔案配置為

<context-param>
        <param-name>log4jConfigLocation</param-name>
        <param-value>config/log4j.properties</param-value>
    </context-param>
    <!-- 3000表示 開一條watchdog線程每60秒掃描一下配置檔案的變化;這樣便于日志存放位置的改變 -->
    <context-param>
        <param-name>log4jRefreshInterval</param-name>
        <param-value>3000</param-value>
    </context-param>
    <listener>
        <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
    </listener>
           
當使用xml檔案配置時
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "log4j.dtd">
<log4j:configuration>
    <!-- [控制台STDOUT] -->
    <appender name="console" class="org.apache.log4j.ConsoleAppender">
        <param name="encoding" value="GBK" />
        <param name="target" value="System.out" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%-5p %c{2} - %m%n" />
        </layout>
    </appender>

    <!-- [公共Appender] -->
    <appender name="DEFAULT-APPENDER" class="org.apache.log4j.DailyRollingFileAppender">
        <param name="File" value="${webapp.root}/logs/common-default.log" />
        <param name="Append" value="true" />
        <param name="encoding" value="GBK" />
        <param name="DatePattern" value="'.'yyyy-MM-dd'.log'" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%d %-5p %c{2} - %m%n" />
        </layout>
    </appender>

    <!-- [錯誤日志APPENDER] -->
    <appender name="ERROR-APPENDER" class="org.apache.log4j.DailyRollingFileAppender">
        <param name="File" value="${webapp.root}/logs/common-error.log" />
        <param name="Append" value="true" />
        <param name="encoding" value="GBK" />
        <param name="threshold" value="error" />
        <param name="DatePattern" value="'.'yyyy-MM-dd'.log'" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%d %-5p %c{2} - %m%n" />
        </layout>
    </appender>

    <!-- [元件日志APPENDER] -->
    <appender name="COMPONENT-APPENDER"
              class="org.apache.log4j.DailyRollingFileAppender">
        <param name="File" value="${webapp.root}/logs/logistics-component.log" />
        <param name="Append" value="true" />
        <param name="encoding" value="GBK" />
        <param name="DatePattern" value="'.'yyyy-MM-dd'.log'" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%d %-5p %c{2} - %m%n" />
        </layout>
    </appender>

    <!-- [元件日志] -->
    <logger name="LOGISTICS-COMPONENT">
        <level value="${loggingLevel}" />
        <appender-ref ref="COMPONENT-APPENDER" />
        <appender-ref ref="ERROR-APPENDER" />
    </logger>

    <!-- Root Logger -->
    <root>
        <level value="${rootLevel}"></level>
        <appender-ref ref="DEFAULT-APPENDER" />
        <appender-ref ref="ERROR-APPENDER" />
    </root>
</log4j:configuration>  
           

此時web.xml需要配置

<!-- log4j配置,檔案路徑,因為是跟随項目啟動 -->
    <context-param>
        <param-name>log4jConfigLocation</param-name>
        <param-value>config/log4j.xml</param-value>
    </context-param>
    <!-- 配置log4j.xml變量,如果需要動态的就使用下面方式,使用方法${name} -->
    <context-param>
        <param-name>controller</param-name>
        <param-value>controller-log</param-value>
    </context-param>

    <context-param>
        <param-name>loggingLevel</param-name>
        <param-value>info</param-value>
    </context-param>
    <!-- 加載log4j配置檔案 -->
    <listener>
        <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
    </listener>
           

2種方法個人比較喜歡用properties檔案,友善修改參數

Controller中使用

先建立logger對象

private static final Logger logger = LoggerFactory.getLogger(LoginController.class);
           

然後在方法中使用就可以了

logger.info ("index ----------------");
        logger.error("index ----------------");
        logger.warn ("index ----------------");
           
配置檔案解釋

1.配置根Logger,其文法為:

其中,level 是日志記錄的優先級,分為OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定義的級别。Log4j建議隻使用四個級别,優 先級從高到低分别是ERROR、WARN、INFO、DEBUG。通過在這裡定義的級别,您可以控制到應用程式中相應級别的日志資訊的開關。比如在這裡定 義了INFO級别,則應用程式中所有DEBUG級别的日志資訊将不被列印出來。 appenderName就是指B日志資訊輸出到哪個地方。您可以同時指定多個輸出目的地。

2.配置日志資訊輸出目的地Appender,其文法為:

log4j.appender.appenderName = fully.qualified.name.of.appender.class  
log4j.appender.appenderName.option1 = value1  
…  
log4j.appender.appenderName.option = valueN
           

其中,Log4j提供的appender有以下幾種:

org.apache.log4j.ConsoleAppender(控制台),  
org.apache.log4j.FileAppender(檔案),  
org.apache.log4j.DailyRollingFileAppender(每天産生一個日志檔案),  
org.apache.log4j.RollingFileAppender(檔案大小到達指定尺寸的時候産生一個新的檔案),  
org.apache.log4j.WriterAppender(将日志資訊以流格式發送到任意指定的地方)
           

3.配置日志資訊的格式(布局),其文法為:

log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class  
log4j.appender.appenderName.layout.option1 = value1  
…  
log4j.appender.appenderName.layout.option = valueN
           

其中,Log4j提供的layout有以e幾種:

org.apache.log4j.HTMLLayout(以HTML表格形式布局),  
org.apache.log4j.PatternLayout(可以靈活地指定布局模式),  
org.apache.log4j.SimpleLayout(包含日志資訊的級别和資訊字元串),  
org.apache.log4j.TTCCLayout(包含日志産生的時間、線程、類别等等資訊)
           

Log4J采用類似C語言中的printf函數的列印格式格式化日志資訊,列印參數如下: %m 輸出代碼中指定的消息

%p 輸出優先級,即DEBUG,INFO,WARN,ERROR,FATAL  
%r 輸出自應用啟動到輸出該log資訊耗費的毫秒數  
%c 輸出所屬的類目,通常就是所在類的全名  
%t 輸出産生該日志事件的線程名  
%n 輸出一個回車換行符,Windows平台為“rn”,Unix平台為“n”  
%d 輸出日志時間點的日期或時間,預設格式為ISO8601,也可以在其後指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},輸出類似:2002年10月18日 22:10:28,921  
%l 輸出日志事件的發生位置,包括類目名、發生的線程,以及在代碼中的行數。舉例:Testlog4.main(TestLog4.java:10)
           

參考文章:http://www.codeceo.com/article/log4j-usage.html

參考文章:http://www.yiibai.com/log4j/log4j_logging_database.html

繼續閱讀