spring boot使用logback實現(xiàn)多環(huá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包。此種解決方案,產生的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)測試與生產的war/jar包代碼不一致的問題(第一種方案在測試打包后,生產打包前,可能會有代碼提交,需人工控制此階段的行為)。
本文基于第二種配置方案,但在使用logback作為日志方案時,產生了一些問題, 具體見下文。
問題1:
使用application.yml配置多環(huán)境變量,使用logback.xml實現(xiàn)日志配置,不能實現(xiàn)多環(huán)境配置(即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),發(fā)現(xiàn)問題之所在
即,logback.xml加載早于application.yml,需改用logback-spring.xml實現(xiàn)日志配置
問題2:
經上修改后,發(fā)現(xiàn)配置文件已生效,但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中l(wèi)og.path: others(info, error),日志都為以上內容
查看官方文檔
官方文檔指明,需要使用<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.本文暫不討論使用配置中心實現(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。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- IDEA?設置?SpringBoot?logback?彩色日志的解決方法?附配置文件
- Springboot使用Logback實現(xiàn)日志配置與異常記錄
- SpringBoot項目的logback日志配置(包括打印mybatis的sql語句)
- Spring Boot日志技術logback原理及配置解析
- springboot配置logback日志管理過程詳解
- 基于logback 實現(xiàn)springboot超級詳細的日志配置
- 詳解Spring Boot配置使用Logback進行日志記錄的實戰(zhàn)
- 詳解Spring Boot 使用slf4j+logback記錄日志配置
- 如何為?Spring?Boot?項目配置?Logback?日志
相關文章
Maven編譯錯誤:程序包com.sun.*包不存在的三種解決方案
J2SE中的類大致可以劃分為以下的各個包:java.*,javax.*,org.*,sun.*,本文文章主要介紹了maven編譯錯誤:程序包com.sun.xml.internal.ws.spi不存在的解決方案,感興趣的可以了解一下2024-02-02解決Springboot @WebFilter攔截器未生效問題
這篇文章主要介紹了解決Springboot @WebFilter攔截器未生效問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10Java 高并發(fā)九:鎖的優(yōu)化和注意事項詳解
本文主要介紹Java高并發(fā)鎖的優(yōu)化和注意事項,這里整理了詳細的資料,并講解了 1. 鎖優(yōu)化的思路和方法 2. 虛擬機內的鎖優(yōu)化 3. 一個錯誤使用鎖的案例 4. ThreadLocal及其源碼分析等知識,有需要的小伙伴可以參考下2016-09-09java servlet手機app訪問接口(一)數(shù)據(jù)加密傳輸驗證
這篇文章主要為大家詳細介紹了java servlet手機app訪問接口(一),數(shù)據(jù)加密傳輸驗證,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12