码迷,mamicode.com
首页 > 其他好文 > 详细

log4j&&logback

时间:2015-08-06 15:15:22      阅读:114      评论:0      收藏:0      [点我收藏+]

标签:log4j   logback   

记录日志好帮手

log4j

log4j参考:
入门
示例
参数详解
Log4j中有三个主要的组件,它们分别是 Logger、Appender和Layout

Log4j 允许开发人员定义多个Logger,每个Logger拥有自己的名字,Logger之间通过名字来表明隶属关系。有一个Logger称为Root,它永远 存在,且不能通过名字检索或引用,可以通过Logger.getRootLogger()方法获得,其它Logger通过 Logger.getLogger(String name)方法。

Appender则是用来指明将所有的log信息存放到什么地方,Log4j中支持多种appender,如 console、files、GUI components、NT Event Loggers等,一个Logger可以拥有多个Appender,也就是你既可以将Log信息输出到屏幕,同时存储到一个文件中。

Layout的作用是控制Log信息的输出方式,也就是格式化输出的信息。
Log4j中将要输出的Log信息定义了5种级别,依次为DEBUG、INFO、WARN、ERROR和FATAL,当输出时,只有级别高过配置中规定的 级别的信息才能真正的输出


logback

入门
配置
异步等高级特性
异步实例
AsyncAppender并不处理日志,只是将日志缓冲到一个BlockingQueue里面去,并在内部创建一个工作线程从队列头部获取日志,之后将获取的日志循环记录到附加的其他appender上去,从而达到不阻塞主线程的效果。因此AsynAppender仅仅充当事件转发器,必须引用另一个appender来做事

注意logger中name选项,资料上说是一个包/类,当其中的运行时,log.info(“”);即可记录。其实name放的就是个字符串,以.为分割层层解析。若仅用于一类,只要在使用时new的参数传入的字符串一致即可。

<?xml version="1.0" encoding="UTF-8"?>
<!-- Logback Configuration. -->
<configuration>
    ## 供开发模式下使用,把信息输出到控制台
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">  
            <pattern>%d %-5p %F:%L - %m%n</pattern>
             <charset>UTF-8</charset> 
        </encoder>
    </appender>

    ## 应用本身以外的日志输出到文件root.log
    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${alibaba_havana_club_output}/root.log</file> 
        <param name="append" value="true"/>
        <append>true</append>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${alibaba_havana_club_output}/root.log.%d{yyyy-MM-dd}</fileNamePattern>  
            <!-- 日志最大的历史7天 -->  
            <maxHistory>7</maxHistory>  
        </rollingPolicy>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">  
            <pattern>%d %-5p %F:%L - %m%n</pattern>
            <charset>UTF-8</charset> <!-- 编码格式 -->  
        </encoder>
    </appender>

    <appender name="OPERATOR_LOGGER" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${alibaba_havana_club_output}/operator.log</file> 
        <param name="append" value="true"/>
        <append>true</append>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${alibaba_havana_club_output}/operator.log.%d{yyyy-MM-dd}</fileNamePattern>  
            <!-- 日志最大的历史7天 -->  
            <maxHistory>7</maxHistory>  
        </rollingPolicy>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">  
            <pattern>%m%n</pattern>
            <charset>UTF-8</charset> 
        </encoder>
    </appender>

    <appender name="OUT_INVOKE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${alibaba_havana_club_output}/root.log</file> 
        <param name="append" value="true"/>
        <append>true</append>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${alibaba_havana_club_output}/out_invoke.log.%d{yyyy-MM-dd}</fileNamePattern>  
            <!-- 日志最大的历史7天 -->  
            <maxHistory>7</maxHistory>  
        </rollingPolicy>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">  
            <pattern>%d %-5p %F:%L - %m%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>


     <appender name ="ASYNC" class= "ch.qos.logback.classic.AsyncAppender">  

            <discardingThreshold >0</discardingThreshold>  

            <queueSize>512</queueSize>  

         <appender-ref ref ="OPERATOR_LOGGER"/>  
          <charset>UTF-8</charset> 
     </appender>  


    <logger name="com.alibaba.havana.club" additivity="false">
        <level value="WARN"/>
        <appender-ref ref="FILE"/>
    </logger>
    <logger name="operatorLogger" additivity="false">
        <level value="INFO" />
        <appender-ref ref="ASYNC" />
    </logger>
    <logger name="outLogger" additivity="false">
        <level value="INFO" />
        <appender-ref ref="OUT_INVOKE" />
    </logger>

    <root level="ERROR" >
        <appender-ref ref="FILE" />
    </root>
</configuration>

版权声明:本文为博主原创文章,未经博主允许不得转载。

log4j&&logback

标签:log4j   logback   

原文地址:http://blog.csdn.net/gg_gogoing/article/details/47315117

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!