spring boot使用logback实现多环境日志配置详解

作者:封巍 时间:2022-10-03 20:38:24 

软件生存周期中,涉及代码运行的环节有编码、测试和维护阶段,而一套成熟的代码,在此三个阶段,数据库、日志路径、日志级别、线程池大小等配置一般会不一样。作为开发人员,希望将代码与配置解耦合,不同的环境,代码一套,而配置多套。

针对于多环境的配置,可以使用maven的profile及filter配置,在打包环节通过打包命令 mvn clean package -P dev/test/product决定所打环境的war/jar包。此种解决方案,产生的war\jar包在不同环境的是不同的,因此MD5校验和也不同。一次敏捷开发结束后,开发、测试、线上的的war/jar包,只能人为添加标识来识别,比如test-1.0.1和prod-1.0.1是功能相同、环境不同的war/jar包。如果是spring boot项目,可以使用yaml配置,实现多环境配置,在项目启动时,通过添加参数--spring.profiles.active=dev/test/production,指定项目运行的环境。此方案的jar包在不同运行环境均是一个,不会出现测试与生产的war/jar包代码不一致的问题(第一种方案在测试打包后,生产打包前,可能会有代码提交,需人工控制此阶段的行为)。

本文基于第二种配置方案,但在使用logback作为日志方案时,产生了一些问题, 具体见下文。

问题1:

使用application.yml配置多环境变量,使用logback.xml实现日志配置,不能实现多环境配置(即logback配置未生效),打印的日志路径和日志级别不是配置文件中的值。

项目配置文件-application.yml 


spring:
profiles.active: dev
---
spring:
profiles: dev
log:
path: ./logs
level: debug
---
spring:
profiles: test
log:
path: /home/user/logs/
level: info
---

日志配置文件-logback.xml


<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true" scan="true" scanPeriod="30 seconds">

<appender name="STDOUT">
   <encoder>
     <pattern>%d{yyyy-MM-dd HH:mm:ss} [%level] [%class:%line] - %m %n</pattern>
   </encoder>
 </appender>

<appender name="FILE-OUT">
   <file>${log.path}/xxx.log</file>
   <encoder>
     <pattern>%d{yyyy-MM-dd HH:mm:ss} [%level] [%class:%line] - %m %n</pattern>
   </encoder>
   <rollingPolicy>
     <fileNamePattern>${log.path}/xxx.%d{yyyy-MM-dd}.log.zip</fileNamePattern>
     <!-- 30 days -->
     <maxHistory>30</maxHistory>
   </rollingPolicy>
 </appender>

<root level="${log.level}">
   <appender-ref ref="STDOUT" />
   <appender-ref ref="FILE-OUT" />
 </root>
</configuration>

查阅官方文档( http://docs.spring.io/spring-boot/docs/current/reference/htmlsingle/#boot-features-custom-log-levels),发现问题之所在

spring boot使用logback实现多环境日志配置详解

spring boot使用logback实现多环境日志配置详解

即,logback.xml加载早于application.yml,需改用logback-spring.xml实现日志配置

问题2:

经上修改后,发现配置文件已生效,但logback-spring.xml中的变量并未生效,日志内容见下


11:41:11,450 |-INFO in c.q.l.core.rolling.TimeBasedRollingPolicy@962287291 - Will use the pattern log.path_IS_UNDEFINED/error.%d{yyyy-MM-dd}.log for the active file
11:41:11,453 |-INFO in c.q.l.core.rolling.DefaultTimeBasedFileNamingAndTriggeringPolicy - The date pattern is 'yyyy-MM-dd' from file name pattern 'log.path_IS_UNDEFINED/error.%d{yyyy-MM-dd}.log.zip'.

...

11:41:11,471 |-INFO in ch.qos.logback.classic.joran.action.RootLoggerAction - Setting level of ROOT logger to DEBUG

看似log.level已生效,log.path未生效,其实不然,经修改application.yml中log.path: others(info, error),日志都为以上内容

查看官方文档

spring boot使用logback实现多环境日志配置详解

官方文档指明,需要使用<springProperty>,才可使用application.properties(或application.yml)中的值

经修改logback-spring.xml后,问题解决

最终的日志配置文件-logback-spring.xml


<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true" scan="true" scanPeriod="30 seconds">
 <springProperty scope="context" name="logLevel" source="log.level"/>
 <springProperty scope="context" name="logPath" source="log.path"/>

<appender name="STDOUT">
   <encoder>
     <pattern>%d{yyyy-MM-dd HH:mm:ss} [%level] [%class:%line] - %m %n</pattern>
   </encoder>
 </appender>

<appender name="FILE-OUT">
   <file>${logPath}/xxx.log</file>
   <encoder>
     <pattern>%d{yyyy-MM-dd HH:mm:ss} [%level] [%class:%line] - %m %n</pattern>
   </encoder>
   <rollingPolicy>
     <fileNamePattern>${logPath}/xxx.%d{yyyy-MM-dd}.log.zip</fileNamePattern>
     <!-- 30 days -->
     <maxHistory>30</maxHistory>
   </rollingPolicy>
 </appender>

<root level="${logLevel}">
   <appender-ref ref="STDOUT" />
   <appender-ref ref="FILE-OUT" />
 </root>
</configuration>

备注:

1.本文暂不讨论使用配置中心实现多环境配置管理

2. How to package a maven program?

mvn clean package [-Dmaven.test.skip]

3.How to start a spring boot program?

java -jar xxx-1.0.0.jar --spring.profiles.active=dev(default)/test/production [--log.level=debug]

其中,--log.level仍可以修改--spring.profiles.active生效后的变量值,可用于线上环境debug(不用重新打包,重新启动即可),但是不建议线上debug。

来源:https://blog.csdn.net/vitech/article/details/53812137

标签:spring,boot,logback,多环境,日志
0
投稿

猜你喜欢

  • C#实现对文件进行加密解密的方法

    2023-05-28 14:02:44
  • 基于Lucene的Java搜索服务器Elasticsearch安装使用教程

    2022-05-31 05:05:10
  • Android BottomNavigationView结合ViewPager实现底部导航栏步骤详解

    2021-09-01 00:42:38
  • Kotlin基础教程之面向对象

    2023-06-21 19:54:36
  • C#判断字符串是否存在字母及字符串中字符的替换实例

    2022-04-15 03:49:48
  • c#调用arcgis地图rest服务示例详解(arcgis地图输出)

    2023-03-05 14:56:05
  • 解决springboot启动失败的问题('hibernate.dialect' not set)

    2023-11-09 03:21:21
  • Java中Calendar类的一些常用方法小结

    2022-11-21 06:51:06
  • Android检查手机网络状态及网络类型的方法

    2023-12-03 19:35:49
  • java实现图片缩放、旋转和马赛克化

    2021-07-23 03:04:54
  • 如何基于SpringBoot实现人脸识别功能

    2022-04-19 13:23:21
  • JAVA IO API使用详解

    2021-07-27 14:45:48
  • Java synchronized锁升级jol过程详解

    2023-04-15 04:58:51
  • SpringBoot AOP AspectJ切面技术介绍与实现方式

    2022-12-27 22:03:53
  • 学习Java九大内置对象

    2023-10-13 01:10:10
  • Java实现的质因数分解操作示例【基于递归算法】

    2023-08-19 03:22:12
  • Android消息机制Handler深入理解

    2023-03-13 13:44:04
  • 聊聊@RequestBody和Json之间的关系

    2023-11-27 03:31:45
  • 基于Android 实现图片平移、缩放、旋转同时进行

    2023-05-30 08:30:51
  • Android Retrofit框架的使用

    2023-10-05 13:24:21
  • asp之家 软件编程 m.aspxhome.com