java日志組件需要知道的幾件事

jopen 9年前發布 | 47K 次閱讀 Java日志組件 日志處理

java日志需要知道的幾件事。由于現在開源框架日益豐富,好多開源框架使用的日志組件不盡相同。存在著在一個項目中,不同的版本,不同的框架共存。導致日志輸出異常混亂。

    由于現在開源框架日益豐富,好多開源框架使用的日志組件不盡相同。存在著在一個項目中,不同的版本,不同的框架共存。
    其中有一些標準通用接口,標準實現,各種橋接器的存在,下面就讓筆者樹立一下這些框架之間的關系。 


slf4J與舊日志框架的關系 

slf4j等于commons-logging,是各種日志實現的通用入口,會根據classpath中存在下面哪一個Jar來決定具體的日志實現庫。 

logback-classic(默認的logback實現) 
slf4j-jcl.jar(apache commons logging) 
slf4j-logj12.jar(log4j 1.2.4) 
slf4j-jdk14(java.util.logging) 

將所有使用舊式日志API的第三方類庫或舊代碼的日志調用轉到slfj 

jcl-over-slf4j.jar/jcl104-over-slf4j:apache commons logging 1.1.1/1.0.4,直接替換即可。 
log4j-over-slf4j.jar:log4j,直接替換即可。 
jul- to-slf4j:jdk logging,需要在程序開始時調用SLF4JBridgeHandler.install()來注冊listener參考 JulOverSlf4jProcessor,可在applicationContext.xml中定義該bean來實現初始化。注意原有的 log4j.properites將失效,logback網站上提供轉換器,支持從log4j.properties 轉換到logback.xml 。 


如何配置Logback

<dependency>

<groupId>org.slf4j</groupId>

<artifactId>slf4j-api</artifactId>

<version>${slf4j.api.version}</version>

</dependency>

<!-- logback -->

<dependency>

<groupId>ch.qos.logback</groupId>

<artifactId>logback-core</artifactId>

<version>1.1.0</version>

<type>jar</type>

</dependency>

<dependency>

<groupId>ch.qos.logback</groupId>

<artifactId>logback-classic</artifactId>

<version>1.1.0</version>

<type>jar</type>

</dependency>

<dependency>

<groupId>org.slf4j</groupId>

<artifactId>log4j-over-slf4j</artifactId>

<version>1.6.6</version>

</dependency>

<dependency>

<groupId>org.slf4j</groupId>

<artifactId>jcl-over-slf4j</artifactId>

<version>1.6.6</version>

</dependency></pre>

 與遺留Logging框架兼容


SLF4J對于Log4J 1和Apache commons Logging的支持方式是提供了實現Log4j和Apache commons Logging接口的SLF4J實現。使用方式是

  1. 去取對Log4J和Apache commons Logging的Jar包的引用

    </li>

  2. 引入SLF4J的對應接口的實現包。

    </li> </ol>

     移除引用

    如果你的系統是直接的使用了Log4j或者Apache commons Logging框架的話,你可以直接把對他們的引用去掉就可以了。如果是你所引用的第三方包里面引用了Log4j或者Apache commons Logging,可以使用<exclusions>標簽去掉對他們的引用,如下所示:

    <dependency>
      <groupId>org.springframework.ldap</groupId>
      <artifactId>spring-ldap-core</artifactId>
      <exclusions>
          <exclusion>
              <artifactId>commons-logging</artifactId>
              <groupId>commons-logging</groupId>
          </exclusion>
      </exclusions>
    </dependency>

    logback.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <configuration scan="true" scanPeriod="30 seconds">
        <!--Appendar詳解: http://logback.qos.ch/manual/appenders.html#RollingFileAppender -->
        <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!-- 當前Log文件名 -->
            <file>ldap-pwd.log</file>
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!-- 非當天的Log文件壓縮備份為 archive/ldap-pwd.2014-08-10.zip -->
                <fileNamePattern>archive/ldap-pwd.%d{yyyy-MM-dd}.zip</fileNamePattern>
                <!-- 超過30天的備份文件會被刪除 -->
                <maxHistory>30</maxHistory>
            </rollingPolicy>

        <layout class="ch.qos.logback.classic.PatternLayout">
            <!-- 格式說明:http://logback.qos.ch/manual/layouts.html#ClassicPatternLayout -->
            <Pattern>%d [%thread] %-5level %40logger{40} - %msg%n</Pattern>
        </layout>
    </appender>
    
    <logger name="cn.justfly.training.logging" level="info" />
    
    <root level="warn">
        <appender-ref ref="FILE" />
    </root>
    

    </configuration></pre>


    </div>

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!