SpringBoot项目读取外置logback配置文件的问题及解决

SpringBoot读取外置logback配置文件

springboot项目可以读取外置配置文件,避免了修改配置文件需要重新打包部署的问题。

部署项目的时候可以在jar包同一目录下新建了config文件夹,将所有的配置文件都放在config文件夹下统一管理,springboot会优先读取jar包同一目录下config目录下的配置文件

下次需要修改配置文件内容就直接在config目录下修改,然后重启项目即可。

问题

启动jar包,却出现了问题:springboot读取的logback-spring.xml还是项目内置的,并没有读取外置的config目录下的logback-spring.xml。经过测试,发现其他配置文件如application.yml的读取都是没问题的,就只有logback配置文件读取没有按预想来。

解决

猜想是因为springboot默认读取的就是项目的resources目录下的logback配置文件

所以解决思路是在启动jar包命令中指定logback配置文件路径:

java -jar -Dlogging.config=./config/logback-spring.xml datasync-web.jar

这样启动jar包即可读取config目录下的logback-spring.xml了。

SpringBoot Logback的使用

springboot引入logback jar以后,自动的会在资源根目录找logback.xml 或 logback-spring.xml文件。

标签定义

  • configuration
属性 作用
scan 当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为
truescanPeriod 设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒。当scan为true时,此属性生效。默认的时间间隔为1分钟。
debug 当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false。

property

和redis的key和value的作用相同。

属性 作用
name 变量的名称
value 变量的值
  • appender

用来格式化日志输出节点。

字段 类型 作用
name 属性 定义名称,方便root引用这个输出策略
class 属性 指定哪种输出策略,常用就是控制台输出策略和文件输出策略
layout 节点 控制台输出使用
encode 节点 文件输出使用
  • loger

设置某一个包或某一个类的日志打印级别。

属性 作用
name 用来指定受此loger约束的某一个包或者具体的某一个类
level 用来设置打印级别,大小写无关:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF,还有一个特俗值INHERITED或者同义词NULL,代表强制执行上级的级别。如果未设置此属性,那么当前loger将会继承上级的级别。
addtivity 是否向上级loger传递打印信息。默认是true。
  • root

必选节点,用来指定最基础的日志输出级别,只有一个level属性用来设置打印级别,只会输出>=level级别的日志。

日志级别,从低到高TRACE > DEBUG > INFO > WARN > ERROR > FATAL。

yml设置打印级别

设置只打印com.spring.logback包下info级别的日志。

logging:
  level:
    com.spring.logback: info

示例


    
    
        
        ERROR
        
        DENY
        
        ACCEPT
    
    
    ${logback.logdir}/info.${logback.appname}.log
    
    
        
        ${logback.logdir}/info.${logback.appname}.%d{yyyy-MM-dd}.log
        
        90
        
        
    
    
    
        UTF-8
        %d [%thread] %-5level %logger{36} %line - %msg%n
    


    
    
        Error
    
    
    ${logback.logdir}/error.${logback.appname}.log
    
    
        
        ${logback.logdir}/error.${logback.appname}.%d{yyyy-MM-dd}.log
        
        90
        
        
    
    
    
        UTF-8
        %d [%thread] %-5level %logger{36} %line - %msg%n
    

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。 

你可能感兴趣的:(SpringBoot项目读取外置logback配置文件的问题及解决)