由于项目控制台打印不出日志,所以学习了log4j,所以来总结一下。
有properties和xml两种形式,下面来以xml形式来学习一下。
在web.xml中配置对应的log4j的监听器。
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
一、节点介绍
- < configuration>顶级节点
- < 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>
- < 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(控制台)里,只会单独打印在指定的日志文件。
- < root>
是< logger>的 根元素,只有一个level属性。
<root level="info">
<appender-ref ref="STDOUT"/>
</root>