Bootstrap

SpringBoot (八)日志配置

       SpringBoot日志:Springboot内部采用的是Commons Logging 进行日志记录,但在底层为Java Util,Loggin,Log4J,Logback等日志框架提供默认配置,虽然有很多可用日志框架,一般使用SpringBoot默认的Logback即可,Logback效率更高,支持SLF4J。

1. 日志依赖:

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

     注:spring-boot-starter中包含了springboot-starter-logging

2. 日志格式:

注:输出如下内容:

       时间日期:精确到毫秒,可以用于排序                 日志级别:ERROR,WARN,INFO,DEBUG,TRACE;

       进程ID:                                                                   分割符:采用---来标识日志开始部分;

       线程名:方括号括起来;                                       Logger名:通常使用源代码的类名;

       日志内容:日志输出的信息

3.日志输出级别:

     SpringBoot默认输出的日志级别为:INFO,WARN,ERROR;

     日志级别从低到高为:TRACE<DEBUG<INFO<WARN<ERROR<FATA 若设置为WARN 则低于WARN级别的信息不会输出

      如需输出更多日志可以通过以下方式开启:

           命令模式配置:Java -jar app.jar -debug=true 这种命令会被SpringBoot解析,优先级最高;

           资源文件配置:application.properties 配置debug=true 即可

4.输出级别配置:

      所有支持的日志记录系统都可以在spring环境中设置记录级别(application.properties)

     格式为:logging.level.* = LEVEL;

                   loggging.level :日志级别控制前缀,*为表名或loggger名;

                   LEVEL 选项:TRACE,DEBUG,INFO,WARN,ERROR,FATAL,OFF;

     例子:logging.level.root =DEBUG root日志以DEUBG级别输出;

                logging.level.com.wuxia=DEBUG com.wuxia包下的所有class以DEBUG级别输出;

#日志配置
logging.level.root=info
logging.level.org.springframework.web=debug
logging.level.org.mybatis= INFO
logging.level.com.com.fyl.navigation.dao=debug

5.日志输出位置:

        默认情况下,Springboot仅将日志输出到控制台,不会写入到日志文件中去,如果除了控制台输出之外还想写日志文件,则需要在application.proterties设置logging.file或logging.path属性;

        logging.file :将日志写入到指定的文件中,默认为相对路径,可以设置为绝对路径。

        logging.path:将名为spring.log写入到指定的文件夹中

        注:如果只配置logging.file,会在项目的当前路径下生成一个xxx.log日志文件

               如果只配置logging.path,会在指定文件夹下生成一个日志文件spring.log 二者不能同时用,同时用只logging.file生效;

         默认日志文件达到10MB时进行切割,产生新的日志文件:(spring.1.log,spring.2.log);

    logging.file.max-size=10MB
    logging.file.max-history=10

6.自定义日志配置

            日志文件一般在ApplcationContext创建前就初始化了,所以不是必须通过spring的配置文件控制,可以外部添加配置文件控制日志:

           根据不同的日志系统,按如下规则建立配置文件名,就可以被加载:

          Logback:logback-spring.xml,logback-spring.groovy,logback.xml,logback.groovy;

          Log4j:log4j-spring.properties,log4j-spring.xml,log4j.properties,log4j.xml;

          推荐使用带有spring的文件名作为日志文件;一般使用logback-spring.xml 作为配置文件;文件放在resources下;

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <!--定义日志文件的存储地址:-->
    <property name="LOG_HOME" value="D:/logs"></property>
    <property name="LOG_NAME" value="logs"></property>
    <conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter"/>

    <conversionRule conversionWord="wex"
                    converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter"/>
    <conversionRule conversionWord="wEx"
                    converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter"/>
 
    <!--定义文件输出格式-->
    <property name="FILE_LOG_PATTERN"
              value="${FILE_LOG_PATTERN:-%d{yyyy-MM-dd HH:mm:ss.SSS} ${LOG_LEVEL_PATTERN:-%5p} ${PID:- } --- [%t] %-40.40logger{39} : %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"/>

    <property name="CONSOLE_LOG_PATTERN"
              value="${CONSOLE_LOG_PATTERN:-%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"/>
    <!--注意:日志级别文件
                     日志记录采用分级记录,级别与日志文件名相对应,不同级别的日志信息记录到不同的日志文件中:
    -->
    <appender name="consoleLog" class="ch.qos.logback.core.ConsoleAppender">
        <layout class="ch.qos.logback.classic.PatternLayout">D
            <pattern>
                ${CONSOLE_LOG_PATTERN}
            </pattern>
        </layout>
    </appender>
    <appender name="fileInfoLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder> <!--<encoder>表示对日志进行编码-->
            <pattern>${FILE_LOG_PATTERN}</pattern><!-- 日志格式 -->
            <charset>utf-8</charset><!--编码方式 -->
        </encoder>
        <file>${LOG_HOME}/${LOG_NAME}-all.log</file> <!--输出文件位置及文件名-->
        <!--日志记录器的滚动策略,按日期,大小记录-->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern> <!-- 归档日志文件路径 -->
                ${LOG_HOME}/backup/${LOG_NAME}-log-all-%d{yyyy-MM-dd}.%i.log
            </fileNamePattern>
            <maxHistory>30</maxHistory><!-- 保留最近30天 -->
            <totalSizeCap>1GB</totalSizeCap><!--指定日志文件上限,到达上限删除旧文件 -->
            <cleanHistoryOnStart>true</cleanHistoryOnStart>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>5MB</maxFileSize><!-- 日志文件不超过5M,超过拆分文件 -->
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
    </appender>
    <appender name="fileErrorLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!--filter为系统定义的拦截器,使用ThresholdFilter来过滤掉ERROR级别以下的日志文件不输出到文件-->
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>ERROR</level>
        </filter>
        <encoder>
            <pattern>${FILE_LOG_PATTERN}</pattern>
            <charset>utf-8</charset>
        </encoder>
        <file>${LOG_HOME}/${LOG_NAME}-error.log</file> 
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern> 
                ${LOG_HOME}/backup/${LOG_NAME}-log-error-%d{yyyy-MM-dd}.%i.log
            </fileNamePattern>
            <maxHistory>30</maxHistory>
            <totalSizeCap>1GB</totalSizeCap>
            <cleanHistoryOnStart>true</cleanHistoryOnStart>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>5MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
    </appender>
    <!-- 配置多环境日志输出:(prod:生产环境 ,test:测试环境,dev:开发环境 来定义不同日志输出)-->
    <springProfile name="prod">
        <appender-ref ref="fileInfoLog"/>
    </springProfile>
    <springProfile name="dev,test">
        <appender-ref ref="fileErrorLog"/>
    </springProfile>
    <root level="${logging.level.root}">
        <appender-ref ref="consoleLog"/>
        <appender-ref ref="fileInfoLog"/>
        <appender-ref ref="fileErrorLog"/>
    </root>
</configuration>

7.打印日志:

@Service
public class UserServiceImpl implements UserService {
    @Autowired
    private UserMapper userMapper;
    private static Logger logger= LogManager.getLogger("UserService");
    @Override
    public List<User> showUser() {
        logger.info("hello");
        List<User> users = userMapper.showUser();
        return users;
    }
}

   注:每次打印日志都要写private static Logger log=LogManager.getLogger("UserService");很麻烦,可以使用lombok插件;

       在类上写上注解@Slf4j:

@Service
@Slf4j
public class UserServiceImpl implements UserService {
    @Autowired
    private UserMapper userMapper;
    @Override
    public List<User> showUser() {
        log.info("hello");
        List<User> users = userMapper.showUser();
        return users;
    }
}

 

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;