SpringBoot (八)日志配置

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

1. 日志依赖:


    org.springframework.boot
    spring-boot-starter-logging

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

2. 日志格式:

注:输出如下内容:

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

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

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

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

3.日志输出级别:

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

     日志级别从低到高为:TRACE

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

           命令模式配置: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下;



    
    
    
    

    
    
 
    
    

    
    
    
        D
            
                ${CONSOLE_LOG_PATTERN}
            
        
    
    
         
            ${FILE_LOG_PATTERN}
            utf-8
        
        ${LOG_HOME}/${LOG_NAME}-all.log 
        
        
             
                ${LOG_HOME}/backup/${LOG_NAME}-log-all-%d{yyyy-MM-dd}.%i.log
            
            30
            1GB
            true
            
                5MB
            
        
    
    
        
        
            ERROR
        
        
            ${FILE_LOG_PATTERN}
            utf-8
        
        ${LOG_HOME}/${LOG_NAME}-error.log 
        
             
                ${LOG_HOME}/backup/${LOG_NAME}-log-error-%d{yyyy-MM-dd}.%i.log
            
            30
            1GB
            true
            
                5MB
            
        
    
    
    
        
    
    
        
    
    
        
        
        
    

7.打印日志:

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

 

你可能感兴趣的:(SpringBoot系列)