log4j

由于项目控制台打印不出日志,所以学习了log4j,所以来总结一下。
有properties和xml两种形式,下面来以xml形式来学习一下。
在web.xml中配置对应的log4j的监听器。

    <listener>
        <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
    </listener>

一、节点介绍

  1. < configuration>顶级节点
  2. < appender>负责日志组件
  <property name="LOG_DIR" value="${APP_HOME}/logs"/>
    <property name="pattern" value="%d{yyyyMMdd:HH:mm:ss.SSS} [%thread] %-5level  %msg%n"/>
//FileAppender 文件
//ConsoleAppender 控制台
 <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <target>System.out</target>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>${pattern}</pattern>
        </encoder>
    </appender>

//滚动记录日志
    <appender name="REPORT_LOG_INFO" class="ch.qos.logback.core.rolling.RollingFileAppender">
    
       //写入的文件名,要包括目录的。
        <file>${LOG_DIR}/report-info.log</file>
        
        //当发生滚动时,文件重命名,大小,保存天数等参数
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
       <fileNamePattern>${LOG_DIR}/report-info.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
       
       <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>100MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
            <maxHistory>30</maxHistory>
        </rollingPolicy>

        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>INFO</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>${pattern}</pattern>
        </encoder>
    </appender>
  1. < logger>
    用来设置某一个包或者具体的某一个类的日志打印级别、以及指定< appender>
  <logger name="com.souche.replacement.report" level="debug">
        <appender-ref ref="REPORT_LOG_INFO"></appender-ref>
        <appender-ref ref="REPORT_LOG_ERROR"></appender-ref>
        <appender-ref ref="REPORT_LOG_DEBUG"></appender-ref>
    </logger>
     <logger name="org.apache.zookeeper" level="error" additivity="false">
        <appender-ref ref="STDOUT"></appender-ref>
    </logger>

additivity设为false,则子Logger只会在自己的appender里输出,而不会在父Logger的appender里输出。
注意:配置多个logger可以指定不同类或包下打印的日志输出到不同的文件里,name属性值设置为指定的类或包,additivity设置为"false"将只作用于当前appender-ref,即sql不会打印在root指定的appender(控制台)里,只会单独打印在指定的日志文件。

  1. < root>
    是< logger>的 根元素,只有一个level属性。
   <root level="info">
        <appender-ref ref="STDOUT"/>
    </root>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值