snowpage 2013-06-17
最近在学习LogBack相关内容,貌似这东西是Log4j的升级,根据官方说法具体信息参见http://logback.qos.ch/documentation.html,其写文件速度是8或9个微秒,写数据库的时间也在几个毫秒。说是对多线程的日志写入的性能有了大幅度的提升。当前logback有以下几个核心类库:
类库名称 | 是否必要 |
| logback-access-1.0.13.jar | 非必要 |
| logback-classic-1.0.13.jar | 必要 |
| logback-core-1.0.13.jar | 必要 |
| slf4j-api-1.7.5.jar | 必要 |
从其引入的类库可知它是依赖于slf4j的,而logback-access并非是logback的必备包,只有当你需要特殊的日志记录方式,比如socket、数据库方式等等。。
通过对其研究,我写了个测试程序由于Logback是非侵入式的,因此这里列出其配置文件:
<configuration>
<statusListener class="ch.qos.logback.core.status.OnConsoleStatusListener" />
<appender name="ROLLING" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>MqClearLog.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- rollover daily -->
<fileNamePattern>MqClearLog-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<!-- or whenever the file size reaches 100MB -->
<maxFileSize>100MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
</rollingPolicy>
<encoder>
<pattern>%msg%n</pattern>
</encoder>
</appender>
<root level="debug">
<appender-ref ref="ROLLING" />
</root>
</configuration>经测试其输出结果为:
16:22:41,200|-INFOinch.qos.logback.classic.LoggerContext[default]-CouldNOTfindresource[logback.groovy]
16:22:41,200|-INFOinch.qos.logback.classic.LoggerContext[default]-CouldNOTfindresource[logback-test.xml]
16:22:41,200|-INFOinch.qos.logback.classic.LoggerContext[default]-CouldNOTfindresource[logback.xml]
16:22:41,201|-INFOinch.qos.logback.classic.LoggerContext[default]-Settingupdefaultconfiguration.
16:22:41.247[main]INFOchapters.configuration.MyApp2-Enteringapplication.
16:22:41.249[main]DEBUGchapters.configuration.Foo-Diditagain!
16:22:41.249[main]INFOchapters.configuration.MyApp2-Exitingapplication.
之后通过阅读官方文档可知去掉”StatusPrinter.print(lc);“此句则不会打印logback的状态,于是我把其去掉了,可之后的输出结果还是和以前的一样,可官方文档上说只要配置文件正确就不会打印可还是有。后经确认为配置问题即
<statusListener class="ch.qos.logback.core.status.OnConsoleStatusListener" />
此句为将logback的状态信息打印到console上(一般为屏幕)将此去掉一切就都OK了。烦恼了好久的问题。