a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > Java > 正文

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

2019-11-26 09:42:54
字體:
來源:轉載
供稿:網(wǎng)友

軟件生存周期中,涉及代碼運行的環(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ā)結束后,開發(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 

spring: profiles.active: dev---spring: profiles: devlog: path: ./logs level: debug---spring: profiles: testlog: 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),發(fā)現(xiàn)問題之所在



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

問題2:

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

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 file11: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)容

查看官方文檔


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

經(jīng)修改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.本文暫不討論使用配置中心實現(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)容,希望對大家的學習有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 日韩1区2区3区 | 国产一级一级毛片女人精品 | www在线观看国产 | 日本一区二区三区视频免费看 | 久久久久.com | 亚洲自拍偷拍第一页 | 一区二区亚洲视频 | av成人免费 | 蜜臀av性久久久久av蜜臀妖精 | 在线超碰 | 精品免费国产视频 | 成人福利视频 | av免费网站| 娇喘呻吟趴在雪白肉体耸动图 | 中文字幕在线视频免费播放 | 电影91久久久 | 国产一区二区精品久久 | 天天爱天天操 | 久久精品久久综合 | 日韩精品一区二区三区 | 欧美一区二区三区 | 中文字幕在线免费 | 欧美精品片 | 久久久精品亚洲 | 成人精品鲁一区一区二区 | 精品自拍网| 精品国产一区二区三区久久久蜜月 | 精品成人国产 | 日本高清视频一区二区三区 | 二区视频 | 综合视频一区二区三区 | 国产福利资源 | 亚洲成人av | 精品九九九 | 一级毛片免费播放 | 午夜操操| 午夜激情男女 | 五月天婷婷激情视频 | 欧美日韩精品免费 | 久久av资源| 欧美视频一区 |