激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術(shù)及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - spring boot使用logback實現(xiàn)多環(huán)境日志配置詳解

spring boot使用logback實現(xiàn)多環(huán)境日志配置詳解

2021-05-27 13:10封巍 Java教程

這篇文章主要介紹了spring boot使用logback實現(xiàn)多環(huán)境日志配置詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

軟件生存周期中,涉及代碼運行的環(huán)節(jié)有編碼、測試和維護階段,而一套成熟的代碼,在此三個階段,數(shù)據(jù)庫、日志路徑、日志級別、線程池大小等配置一般會不一樣。作為開發(fā)人員,希望將代碼與配置解耦合,不同的環(huán)境,代碼一套,而配置多套。

針對于多環(huán)境的配置,可以使用maven的profile及filter配置,在打包環(huán)節(jié)通過打包命令 mvn clean package -p dev/test/product決定所打環(huán)境的war/jar包。此種解決方案,產(chǎn)生的war\jar包在不同環(huán)境的是不同的,因此md5校驗和也不同。一次敏捷開發(fā)結(jié)束后,開發(fā)、測試、線上的的war/jar包,只能人為添加標識來識別,比如test-1.0.1和prod-1.0.1是功能相同、環(huán)境不同的war/jar包。如果是spring boot項目,可以使用yaml配置,實現(xiàn)多環(huán)境配置,在項目啟動時,通過添加參數(shù)--spring.profiles.active=dev/test/production,指定項目運行的環(huán)境。此方案的jar包在不同運行環(huán)境均是一個,不會出現(xiàn)測試與生產(chǎn)的war/jar包代碼不一致的問題(第一種方案在測試打包后,生產(chǎn)打包前,可能會有代碼提交,需人工控制此階段的行為)。

本文基于第二種配置方案,但在使用logback作為日志方案時,產(chǎn)生了一些問題, 具體見下文。

問題1:

使用application.yml配置多環(huán)境變量,使用logback.xml實現(xiàn)日志配置,不能實現(xiàn)多環(huán)境配置(即logback配置未生效),打印的日志路徑和日志級別不是配置文件中的值。

項目配置文件-application.yml 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
spring:
 profiles.active: dev
---
spring:
 profiles: dev
log:
 path: ./logs
 level: debug
---
spring:
 profiles: test
log:
 path: /home/user/logs/
 level: info
---

日志配置文件-logback.xml

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
<?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),發(fā)現(xiàn)問題之所在

spring boot使用logback實現(xiàn)多環(huán)境日志配置詳解

spring boot使用logback實現(xiàn)多環(huán)境日志配置詳解

即,logback.xml加載早于application.yml,需改用logback-spring.xml實現(xiàn)日志配置

問題2:

經(jīng)上修改后,發(fā)現(xiàn)配置文件已生效,但logback-spring.xml中的變量并未生效,日志內(nèi)容見下

?
1
2
3
4
5
6
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未生效,其實不然,經(jīng)修改application.yml中l(wèi)og.path: others(info, error),日志都為以上內(nèi)容

查看官方文檔

spring boot使用logback實現(xiàn)多環(huán)境日志配置詳解

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

經(jīng)修改logback-spring.xml后,問題解決

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
<?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.本文暫不討論使用配置中心實現(xiàn)多環(huán)境配置管理

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生效后的變量值,可用于線上環(huán)境debug(不用重新打包,重新啟動即可),但是不建議線上debug。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/vitech/article/details/53812137

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久国产精品久久久久久电车 | 亚洲最大av网站 | 毛片福利| 国产三级在线视频观看 | 欧美精品v国产精品v日韩精品 | 91 免费视频 | 黄网站在线免费看 | 成年人高清视频在线观看 | 看一级毛片 | 91超视频| 成人午夜亚洲 | 精品999久久久 | 久久av喷吹av高潮av懂色 | 国产一区二区免费在线观看 | 日本在线精品视频 | 色淫网站免费视频 | 欧美1区2区 | 精品国产一区二区三区四 | 成人免费毛片网站 | 国产精品999在线 | 成人免费一区二区三区视频网站 | 久久污| 中国美女一级黄色大片 | 一级做a爱片性色毛片 | 青青草成人av | 日本人乱人乱亲乱色视频观看 | 成年免费在线视频 | 国产欧美在线观看不卡一 | 国产又白又嫩又紧又爽18p | 99国产精品国产免费观看 | 黄色大片网 | 5xsq在线视频| 国产精品久久久久av | 久久久精彩 | 欧美日韩在线播放 | 国产1区2区3区在线观看 | 久章草在线视频 | 蜜桃视频最新网址 | 欧美一级毛片大片免费播放 | 国产成人高清在线观看 | 免费国产不卡午夜福在线 |