spring-logback引用外部文件實現(xiàn)方式
背景
在spring微服務(wù)開發(fā)和云部署中,都涉及到日志的收集,很多時候為例方便管理和開發(fā),很多公司都會開發(fā)一些基礎(chǔ)配置代碼。其中日志就是很重要的部分,
為了方便部署、收集、查看,所以日志文件需要存儲在同一個目錄下,且日志格式必須是相同的。
但是在微服務(wù)開發(fā)中,如果每個服務(wù)都自己創(chuàng)建的logback-spring.xml文件并配置信息,難免會出現(xiàn)錯誤或者遺漏的地方。所以需要統(tǒng)一的logback-spring.xml配置,但是因為某些需要,可能服務(wù)又會有自己獨特的日志文件記錄。所以需要日志打印不能請控制,必須未服務(wù)留有一定的自主控制。
原理
基于以上的要求,使用logback配置文件的繼承方式,既可以統(tǒng)一需要的日志的打印存儲方式,又可以在一定程度上給與服務(wù)自主開發(fā)的空間。
由于需要引入springboot的一些配置項,所以我們使用spring-logback.xml配置。
因為加載順序:
logback.xml > application.properties/application.yaml > logback-spring.xml
logback的引用實現(xiàn)
logback引入其他的配置項使用<included></included> 和<include></include> 來實現(xiàn)。
從文件中包含
<include file="src/main/java/com/xxxx/configuration/includedConfig.xml"/>
特別注意一點 :logback-include.xml在 maven 中 , 不能直接放在src/resouces路徑下 。
這樣的情況就是 ,logback-include.xml在 jar 的根路徑中 , 但不是跟logback.xml同一目錄 . 在沒有路徑的情況下 , 默認(rèn)只會去找同目錄下的文件 . 就找不到j(luò)ar包里的了 。
<!-- logback.xml --> <configuration> <!-- 這么配置 , 只會找同目錄下的文件 --> <include resource="logback-include.xml" /> </configuration>
從 classpath 中包含
<include resource="includedConfig.xml"/>
從 URL 中包含
<include url="http://some.host.com/includedConfig.xml"/>
如果包含不成功,那么 logback 會打印出一條警告信息,如果不希望 logback 抱怨,只需這樣做:
<include optional="true" ..../>
實現(xiàn)方式
公共基礎(chǔ)配置
先新建一個基礎(chǔ)配置模塊,這個模塊將被打成jar包,并在其他項目中被引用,這個項目中包括了基礎(chǔ)的日志配置,配置信息如下:
logback-base.xml
<included>
<contextName>${APPLICATION_NAME}</contextName>
<springProperty name="APPLICATION_NAME" scope="context" source="spring.application.name" defaultValue="core-logback-base"/>
<springProperty name="LOG_PATH" scope="context" source="logging.file" defaultValue="./log/application/${SERVICE_NAME}"/>
<springProperty name="LOG_MAX_FILE_SIZE" scope="context" source="logback.file.size" defaultValue="50MB"/>
<springProperty name="LOG_FILE_MAX_TIME" scope="context" source="logback.file.maxTime" defaultValue="24"/>
<springProperty name="LOG_FILE_TIME_FORMAT" scope="context" source="logback.file.timeFormat" defaultValue="yyyy-MM-dd'T'HH"/>
<springProperty name="ServerIP" scope="context" source="spring.cloud.client.ip-address" defaultValue="0.0.0.0"/>
<springProperty name="ServerPort" scope="context" source="server.port" defaultValue="0000"/>
<property name="SERVICE_NAME" value="${APPLICATION_NAME}"/>
<property name="LOG_PATTERN" value="[${SERVICE_NAME}] [%d{yyyy-MM-dd HH:mm:ss.SSS}] [%thread] %-5level %logger{30}: %line - %msg %n"/>
<appender name ="InfoLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
<!--指定日志路徑和名稱-->
<file>${LOG_PATH}/${SERVICE_NAME}-info.log</file>
<!--是否使用追加日志的方式-->
<append>true</append>
<!--級別過濾器,只打印指定級別的日志-->
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>INFO</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
<!-- 當(dāng)發(fā)生滾動時,決定RollingFileAppender的行為,涉及文件移動和重命名 -->
<!--SizeAndTimeBasedRollingPolicy 它根據(jù)時間來制定滾動策略,也限制每個文件的大小,既負(fù)責(zé)滾動也負(fù)責(zé)出發(fā)滾動-->
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<!--每天生成一個日志文件,保存maxHistory天的日志文件-->
<!--<fileNamePattern>${LOG_PATH}/rollingFileAppender.%d{yyyy-MM-dd}.log</fileNamePattern>-->
<!--每個分鐘生成一個日志文件,保存maxHistory小時的日志文件-->
<!--<fileNamePattern>${LOG_PATH}/rollingFileAppender.%d{yyyy-MM-dd'T'HH}.-%i.log</fileNamePattern>-->
<!--每個小時生成一個日志文件,保存maxHistory分鐘的日志文件,并且將及時日志文件進(jìn)行壓縮zip-->
<fileNamePattern>${LOG_PATH}/${SERVICE_NAME}.info.%d{${LOG_FILE_TIME_FORMAT}}.log%i.zip</fileNamePattern>
<!--限制每一個log文件的大小-->
<maxFileSize>100MB</maxFileSize>
<maxHistory>${LOG_FILE_MAX_TIME}</maxHistory>
</rollingPolicy>
<encoder>
<!--日志格式-->
<pattern>${LOG_PATTERN}</pattern>
</encoder>
</appender>
<appender name ="ErrorLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
<!--指定日志路徑和名稱-->
<file>${LOG_PATH}/${SERVICE_NAME}-error.log</file>
<!--是否使用追加日志的方式-->
<append>true</append>
<!--級別過濾器,只打印指定級別的日志-->
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>ERROR</level>
</filter>
<!-- 當(dāng)發(fā)生滾動時,決定RollingFileAppender的行為,涉及文件移動和重命名 -->
<!--SizeAndTimeBasedRollingPolicy 它根據(jù)時間來制定滾動策略,也限制每個文件的大小,既負(fù)責(zé)滾動也負(fù)責(zé)出發(fā)滾動-->
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<!--每天生成一個日志文件,保存maxHistory天的日志文件-->
<!--<fileNamePattern>${LOG_PATH}/rollingFileAppender.%d{yyyy-MM-dd}.log</fileNamePattern>-->
<!--每個分鐘生成一個日志文件,保存maxHistory小時的日志文件-->
<!--<fileNamePattern>${LOG_PATH}/rollingFileAppender.%d{yyyy-MM-dd'T'HH}.-%i.log</fileNamePattern>-->
<!--每個小時生成一個日志文件,保存maxHistory分鐘的日志文件,并且將及時日志文件進(jìn)行壓縮zip-->
<fileNamePattern>${LOG_PATH}/${SERVICE_NAME}.error.%d{${LOG_FILE_TIME_FORMAT}}.log%i.zip</fileNamePattern>
<!--限制每一個log文件的大小-->
<maxFileSize>100MB</maxFileSize>
<maxHistory>24</maxHistory>
</rollingPolicy>
<encoder>
<!--日志格式-->
<pattern>${LOG_PATTERN}</pattern>
</encoder>
</appender>
<root level ="INFO">
<appender-ref ref="InfoLog" level ="INFO"/>
<appender-ref ref="ErrorLog" level ="ERROR"/>
</root>
</included>位置不要放在resources下,需要放在java目錄或其子目錄下,假設(shè)起路徑是:
com/test/core/log/xml/logback-base.xml
引用基礎(chǔ)配置
在其他的項目中,我們可以通過maven方式引入公共基礎(chǔ)配置的jar包。然后在項目的resources新建logback-spring.xm引入基礎(chǔ)配置,并加入自己的配置項。
<configuration scan="true" scanPeriod="60 seconds" debug="false">
<include resource="com/test/core/log/xml/logback-base.xml"/>
<!--輸出到控制臺-->
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>${LOG_PATTERN}</pattern>
</encoder>
</appender>
<root level ="INFO">
<!-- 控制臺打印方式 -->
<appender-ref ref="CONSOLE" level="INFO"/>
</root>
</configuration>同時在application.properties或application.yaml中配置日志文件方式:
logging.config=classpath:logback.xml
這樣就完成了所有配置。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
java語言基礎(chǔ)之標(biāo)識符和命名規(guī)則詳解
這篇文章主要給大家介紹了關(guān)于java語言基礎(chǔ)之標(biāo)識符和命名規(guī)則的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
java.lang.IllegalStateException異常原因和解決辦法
這篇文章主要給大家介紹了關(guān)于java.lang.IllegalStateException異常原因和解決辦法,IllegalStateException是Java標(biāo)準(zhǔn)庫中的一個異常類,通常表示在不合適或無效的情況下執(zhí)行了某個方法或操作,需要的朋友可以參考下2023-07-07
Springboot如何同時裝配兩個相同類型數(shù)據(jù)庫
這篇文章主要介紹了Springboot如何同時裝配兩個相同類型數(shù)據(jù)庫,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11
Java字符串格式化功能?String.format用法詳解
String類的format()方法用于創(chuàng)建格式化的字符串以及連接多個字符串對象,熟悉C語言的同學(xué)應(yīng)該記得C語言的sprintf()方法,兩者有類似之處,format()方法有兩種重載形式2024-09-09
被遺忘的Java關(guān)鍵字transient的使用詳解
在 Java 中,transient 是一個關(guān)鍵字,用于指定一個類的字段(成員變量)在序列化時應(yīng)該被忽略。本文將通過示例為大家簡單講講transient的使用,需要的可以參考一下2023-04-04

