日志系统

日志插件:
主流的实现:log4j2,logback,commons-logging,jdk-log
主流的接口:slf4j,spring-jcl
使用spring-jcl + logback 测试
日志记录一般有5个级别:
trace : 路由级别,最低级别。
debug:调试级别,记录调试信息。
info:信息级别,记录一些普通信息。
error:记录错误或异常信息。
fatal:严重系统异常。最高级别。
日志系统,配置文件实例:
首先,需要导入依赖到pom.xml 文件中
<!-- 日志相关包 --> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-core</artifactId> <version>1.2.11</version> </dependency> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> <version>1.2.11</version> </dependency>
在mybatis.xml 中的配置:
<!-- 输出查询语句及相关日志,logImpl属性用于指定MyBatis所用日志的具体实现,未指定时将自动检测。 检测顺序依次为:SLF4J | LOG4J | LOG4J2 | JDK_LOGGING | COMMONS_LOGGING | STDOUT_LOGGING | NO_LOGGING。 STDOUT_LOGGING表示输出到控制台,在整合了springmvc时,推荐选择COMMONS_LOGGING,表示使用spring-jcl进行日志记录, spring对此部分进行了重写,但包名依旧沿用org.apache.commons.logging,可自动匹配日志实现,包括slf4j。 --> <setting name="logImpl" value="COMMONS_LOGGING" /> <!-- logPrefix属性用于指定MyBatis增加到日志名称的前缀,配置此属性,是方便于其它日志记录插件使用。 value值应以点结尾,以与真正的日志名称分隔。若不指定此属性,则默认日志名称的前缀应为dao接口所在包。 如:dao接口为com.situ.dao.CategoryDAO,则日志名称为:com.situ.dao.CategoryDAO,若指定了以下前缀, 则日志名称变为mybatis.dao.com.situ.dao.CategoryDAO,此时日志插件再使用com.situ.dao作为判定输出的前缀,已经无效。 如果项目中的dao接口分散在不同的包里,则此属性就可派上用场,添加此配置后,即所有日志名称均以此配置值为前缀, 那么日志实现就可指定此虚拟的包名mybatis.dao了。注意:一旦指定使用此配置指定前缀,则日志记录插件使用默认的原始包名做前缀将失败 --> <setting name="logPrefix" value="mybatis.dao." />
类的根路径下的logback.xml配置:
<?xml version="1.0" encoding="UTF-8"?> <configuration> <!-- 标准控制台输出 --> <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> <Pattern>%d{HH:mm:ss.SSS} %-5level %logger{80} - %msg%n</Pattern> </encoder> </appender> <!-- 滚动文件输出。配置输出文件路径时,注意windows系统以类似"d:/"开始 --> <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> <file>d:/logs/students2022/logFile.log</file> <!-- 滚动策略 --> <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"> <fileNamePattern>d:/logs/students2022/logFile-%d{yyyy-MM-dd}.%i.zip</fileNamePattern> <maxHistory>30</maxHistory> <maxFileSize>5MB</maxFileSize> <totalSizeCap>100MB</totalSizeCap> </rollingPolicy> <!-- 输出格式 --> <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> <Pattern>%d{HH:mm:ss.SSS} %-5level %logger{80} - %msg%n</Pattern> </encoder> </appender> <!-- 异步文件日志记录器 --> <appender name="AsyncFILE" class="ch.qos.logback.classic.AsyncAppender"> <appender-ref ref="FILE" /> </appender> <!-- 配置日志的输出方式 --> <!-- 开发模式,此处选择了控制台输出。对于生产模式,一般是将日志记录到文件 --> <root> <!-- 输出日志的级别 --> <level value="INFO" /> <!-- 输出到控制台 --> <appender-ref ref="STDOUT" /> <appender-ref ref="FILE" /> </root> <!-- 输出mybatis日志 --> <logger name="mybatis.dao" level="DEBUG" /> </configuration>
本文作者:刘广法,转载注明出处。