SpringBoot 日志配置

221 阅读1分钟

Mybatis内置的日志工厂提供日志功能,具体的日志实现有以下几种工具:

SLF4J Apache Commons Logging Log4j 2 Log4j JDK logging

具体选择哪个日志实现工具由MyBatis的内置日志工厂确定。它会使用最先找到的(按上文列举的顺序查找)。 如果一个都未找到,日志功能就会被禁用。

System_API项目的日志配置为例:

整体架构:

image.png

1、在pom.xml文件中加入依赖

<exclusions>
 
<exclusion>
 
<groupId>org.springframework.boot</groupId>
 
<artifactId>spring-boot-starter-logging</artifactId>
 
</exclusion>
 
</exclusions>

image.png

2、在application.properties 文件中加上配置

image.png

3、application-dev.properties 文件中加入代码

image.png

4、新建logback-log.xml文件

代码如下:

<?xml version="1.0" encoding="UTF-8"?>
 
<configuration>
 
<!-- 说明: 1、日志级别及文件 日志记录采用分级记录,级别与日志文件名相对应,不同级别的日志信息记录到不同的日志文件中 例如:error级别记录到log_error_xxx.log或log_error.log(该文件为当前记录的日志文件),而log_error_xxx.log为归档日志,
 
日志文件按日期记录,同一天内,若日志文件大小等于或大于2M,则按0、1、2...顺序分别命名 例如log-level-2013-12-21.0.log
 
其它级别的日志也是如此。 2、文件路径 若开发、测试用,在Eclipse中运行项目,则到Eclipse的安装路径查找logs文件夹,以相对路径../logs。
 
若部署到Tomcat下,则在Tomcat下的logs文件中 3、Appender FILEERROR对应error级别,文件名以log-error-xxx.log形式命名
 
FILEWARN对应warn级别,文件名以log-warn-xxx.log形式命名 FILEINFO对应info级别,文件名以log-info-xxx.log形式命名
 
FILEDEBUG对应debug级别,文件名以log-debug-xxx.log形式命名 stdout将日志信息输出到控制上,为方便开发测试使用 -->
 
<contextName>usi.system.api</contextName>
 
<property name="LOG_PATH" value="/home/logs" />
 
<!--设置系统日志目录 -->
 
<property name="APP_DIR" value="SystemAPILogging" />
 
 
 
<!-- 不带彩色的日志在控制台输出时候的设置 -->
 
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
 
<encoder>
 
<!-- 格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 -->
 
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} -
 
%msg%n</pattern>
 
</encoder>
 
</appender>
 
 
 
<!-- 日志记录器,日期滚动记录 -->
 
<appender name="FILEERROR"
 
class="ch.qos.logback.core.rolling.RollingFileAppender">
 
<!-- 正在记录的日志文件的路径及文件名 -->
 
<file>${LOG_PATH}/${APP_DIR}/log_error.log</file>
 
<!-- 日志记录器的滚动策略,按日期,按大小记录 -->
 
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
 
<!-- 归档的日志文件的路径,例如今天是2013-12-21日志,当前写的日志文件路径为file节点指定,可以将此文件与file指定文件路径设置为不同路径,从而将当前日志文件或归档日志文件置不同的目录。
 
而2013-12-21的日志文件在由fileNamePattern指定。%d{yyyy-MM-dd}指定日期格式,%i指定索引 -->
 
<fileNamePattern>${LOG_PATH}/${APP_DIR}/error/log-error-%d{yyyy-MM-dd}.%i.log
 
</fileNamePattern>
 
<!-- 除按日志记录之外,还配置了日志文件不能超过2M,若超过2M,日志文件会以索引0开始, 命名日志文件,例如log-error-2013-12-21.0.log -->
 
<timeBasedFileNamingAndTriggeringPolicy
 
class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
 
<maxFileSize>2MB</maxFileSize>
 
</timeBasedFileNamingAndTriggeringPolicy>
 
</rollingPolicy>
 
<!-- 追加方式记录日志 -->
 
<append>true</append>
 
<!-- 日志文件的格式 -->
 
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
 
<pattern>===%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L -
 
%msg%n</pattern>
 
<charset>utf-8</charset>
 
</encoder>
 
<!-- 此日志文件只记录info级别的 -->
 
<filter class="ch.qos.logback.classic.filter.LevelFilter">
 
<level>error</level>
 
<onMatch>ACCEPT</onMatch>
 
<onMismatch>DENY</onMismatch>
 
</filter>
 
</appender>
 
 
 
<!-- 日志记录器,日期滚动记录 -->
 
<appender name="FILEWARN"
 
class="ch.qos.logback.core.rolling.RollingFileAppender">
 
<!-- 正在记录的日志文件的路径及文件名 -->
 
<file>${LOG_PATH}/${APP_DIR}/log_warn.log</file>
 
<!-- 日志记录器的滚动策略,按日期,按大小记录 -->
 
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
 
<!-- 归档的日志文件的路径,例如今天是2013-12-21日志,当前写的日志文件路径为file节点指定,可以将此文件与file指定文件路径设置为不同路径,从而将当前日志文件或归档日志文件置不同的目录。
 
而2013-12-21的日志文件在由fileNamePattern指定。%d{yyyy-MM-dd}指定日期格式,%i指定索引 -->
 
<fileNamePattern>${LOG_PATH}/${APP_DIR}/warn/log-warn-%d{yyyy-MM-dd}.%i.log
 
</fileNamePattern>
 
<!-- 除按日志记录之外,还配置了日志文件不能超过2M,若超过2M,日志文件会以索引0开始, 命名日志文件,例如log-error-2013-12-21.0.log -->
 
<timeBasedFileNamingAndTriggeringPolicy
 
class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
 
<maxFileSize>2MB</maxFileSize>
 
</timeBasedFileNamingAndTriggeringPolicy>
 
</rollingPolicy>
 
<!-- 追加方式记录日志 -->
 
<append>true</append>
 
<!-- 日志文件的格式 -->
 
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
 
<pattern>===%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L -
 
%msg%n</pattern>
 
<charset>utf-8</charset>
 
</encoder>
 
<!-- 此日志文件只记录info级别的 -->
 
<filter class="ch.qos.logback.classic.filter.LevelFilter">
 
<level>warn</level>
 
<onMatch>ACCEPT</onMatch>
 
<onMismatch>DENY</onMismatch>
 
</filter>
 
</appender>
 
 
 
<!-- 日志记录器,日期滚动记录 -->
 
<appender name="FILEINFO"
 
class="ch.qos.logback.core.rolling.RollingFileAppender">
 
<!-- 正在记录的日志文件的路径及文件名 -->
 
<file>${LOG_PATH}/${APP_DIR}/log_info.log</file>
 
<!-- 日志记录器的滚动策略,按日期,按大小记录 -->
 
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
 
<!-- 归档的日志文件的路径,例如今天是2013-12-21日志,当前写的日志文件路径为file节点指定,可以将此文件与file指定文件路径设置为不同路径,从而将当前日志文件或归档日志文件置不同的目录。
 
而2013-12-21的日志文件在由fileNamePattern指定。%d{yyyy-MM-dd}指定日期格式,%i指定索引 -->
 
<fileNamePattern>${LOG_PATH}/${APP_DIR}/info/log-info-%d{yyyy-MM-dd}.%i.log
 
</fileNamePattern>
 
<!-- 除按日志记录之外,还配置了日志文件不能超过2M,若超过2M,日志文件会以索引0开始, 命名日志文件,例如log-error-2013-12-21.0.log -->
 
<timeBasedFileNamingAndTriggeringPolicy
 
class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
 
<maxFileSize>2MB</maxFileSize>
 
</timeBasedFileNamingAndTriggeringPolicy>
 
</rollingPolicy>
 
<!-- 追加方式记录日志 -->
 
<append>true</append>
 
<!-- 日志文件的格式 -->
 
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
 
<pattern>===%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L -
 
%msg%n</pattern>
 
<charset>utf-8</charset>
 
</encoder>
 
<!-- 此日志文件只记录info级别的 -->
 
<filter class="ch.qos.logback.classic.filter.LevelFilter">
 
<level>info</level>
 
<onMatch>ACCEPT</onMatch>
 
<onMismatch>DENY</onMismatch>
 
</filter>
 
</appender>
 
 
 
<!-- 日志记录器,日期滚动记录 -->
 
<appender name="FILEDEBUG"
 
class="ch.qos.logback.core.rolling.RollingFileAppender">
 
<!-- 正在记录的日志文件的路径及文件名 -->
 
<file>${LOG_PATH}/${APP_DIR}/log_debug.log</file>
 
<!-- 日志记录器的滚动策略,按日期,按大小记录 -->
 
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
 
<!-- 归档的日志文件的路径,例如今天是2013-12-21日志,当前写的日志文件路径为file节点指定,可以将此文件与file指定文件路径设置为不同路径,从而将当前日志文件或归档日志文件置不同的目录。
 
而2013-12-21的日志文件在由fileNamePattern指定。%d{yyyy-MM-dd}指定日期格式,%i指定索引 -->
 
<fileNamePattern>${LOG_PATH}/${APP_DIR}/debug/log-debug-%d{yyyy-MM-dd}.%i.log
 
</fileNamePattern>
 
<!-- 除按日志记录之外,还配置了日志文件不能超过2M,若超过2M,日志文件会以索引0开始, 命名日志文件,例如log-error-2013-12-21.0.log -->
 
<timeBasedFileNamingAndTriggeringPolicy
 
class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
 
<maxFileSize>2MB</maxFileSize>
 
</timeBasedFileNamingAndTriggeringPolicy>
 
</rollingPolicy>
 
<!-- 追加方式记录日志 -->
 
<append>true</append>
 
<!-- 日志文件的格式 -->
 
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
 
<pattern>===%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L -
 
%msg%n</pattern>
 
<charset>utf-8</charset>
 
</encoder>
 
<!-- 此日志文件只记录info级别的 -->
 
<filter class="ch.qos.logback.classic.filter.LevelFilter">
 
<level>DEBUG</level>
 
<onMatch>ACCEPT</onMatch>
 
<onMismatch>DENY</onMismatch>
 
</filter>
 
</appender>
 
 
 
<logger name="com.usi" level="debug" />
 
 
 
<!--log4jdbc -->
 
<logger name="jdbc.sqltiming" level="debug" />
 
<logger name="com.ibatis" level="debug" />
 
<logger name="com.ibatis.common.jdbc.SimpleDataSource" level="debug" />
 
<logger name="com.ibatis.common.jdbc.ScriptRunner" level="debug" />
 
<logger name="com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate"
 
level="debug" />
 
<logger name="java.sql.Connection" level="debug" />
 
<logger name="java.sql.Statement" level="debug" />
 
<logger name="java.sql.PreparedStatement" level="debug" />
 
<logger name="java.sql.ResultSet" level="debug" />
 
 
 
<logger name="org.springframework" level="WARN" />
 
 
 
<!-- 生产环境下,将此级别配置为适合的级别,以免日志文件太多或影响程序性能 -->
 
<root level="INFO">
 
<appender-ref ref="FILEERROR" />
 
<appender-ref ref="FILEWARN" />
 
<appender-ref ref="FILEINFO" />
 
<appender-ref ref="FILEDEBUG" />
 
<!-- 生产环境将请stdout,testfile去掉 -->
 
<appender-ref ref="CONSOLE" />
 
</root>
 
</configuration>

5、运行SysmanagerApplication.java文件,启动项目!

6、查看是否生成日志文件。

我是进阶的球儿,大家一起2019年的爬坑历程。感觉分享很给力的话给个赞,谢谢!!!有问题也可以下方留言沟通。