springboot使用logback按日期和大小生成日誌文件

轉自:https://www.ericgg.com/archives/3848.htmlhtml

springboot默認的日誌文件是不會自動按天分割的,因此生產環境的日誌文件愈來愈大,很不利於排錯。查了不少資料最終配置以下,能夠完美按天按錯誤等級分割日誌文件,配置以下。java

因爲springboot採用約定優先於配置的方式,日誌文件也是,SpringBoot項目中在官方文檔中(https://docs.spring.io/spring-boot/docs/current/reference/html/boot-features-logging.html)說明,默認已經依賴了一些日誌框架。而其中推薦使用的就是Logback,說明一下,SpringBoot已經依賴了Logback因此不須要手動添加依賴。web

首先不一樣環境下的logback配置確定是不同的,因此個人解決辦法是:spring

項目中的application.properties已經經過spring.profiles.active來分割成不一樣環境下使用不一樣的properties配置,好比application-dev.properties(開發環境),application-uat.properties(測試環境),application-prod.properties(生產環境),再加上application.properties(這個文件可能只包含spring.profiles.active就夠了,真正的配置可能都在帶-的文件裏,由於springboot默認會加載它,而後經過它來指定使用哪一個文件) 共有4個properties 文件,而後在application.properties 經過spring.profiles.active指定要使用的真正的propertiessql

ok 上面是簡單的聊了一下application.properties配置的問題,正戲來了apache

接下來就要建立出來 logback-spring-dev.xml,logback-spring-uat.xml,logback-spring-prod.xml三個文件,而後在每一個對應環境的properties經過 logging.config 來指定logback 的xml文件tomcat

logging.config=classpath:logback-spring-prod.xmlspringboot

至於logback的xml文件內容以下:app

logback-spring-dev.xml 開發環境下,不須要輸出到文件,只須要打印在控制檯就好了框架

<?xml version="1.0" encoding="UTF-8"?>

<!-- 從高到地低 OFF 、 FATAL 、 ERROR 、 WARN 、 INFO 、 DEBUG 、 TRACE 、 ALL -->
<!-- 日誌輸出規則 根據當前ROOT 級別,日誌輸出時,級別高於root默認的級別時 會輸出 -->
<!-- 如下 每一個配置的 filter 是過濾掉輸出文件裏面,會出現高級別文件,依然出現低級別的日誌信息,經過filter 過濾只記錄本級別的日誌 -->


<!-- 屬性描述 scan:性設置爲true時,配置文件若是發生改變,將會被從新加載,默認值爲true scanPeriod:設置監測配置文件是否有修改的時間間隔,若是沒有給出時間單位,默認單位是毫秒。當scan爲true時,此屬性生效。默認的時間間隔爲1分鐘。 
	debug:當此屬性設置爲true時,將打印出logback內部日誌信息,實時查看logback運行狀態。默認值爲false。 -->
<configuration scan="true" scanPeriod="60 seconds" debug="false">
	<contextName>d1money-web-ys-ems</contextName>

	<!-- ConsoleAppender 控制檯輸出日誌 -->
	<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
		<!-- 對日誌進行格式化 -->
		<encoder>
			<pattern>
				%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger -%msg%n
			</pattern>
		</encoder>
	</appender>

	<logger name="java.sql.PreparedStatement" value="DEBUG" />
	<logger name="java.sql.Connection" value="DEBUG" />
	<logger name="java.sql.Statement" value="DEBUG" />
	<logger name="com.ibatis" value="DEBUG" />
	<logger name="com.ibatis.common.jdbc.SimpleDataSource" value="DEBUG" />
	<logger name="com.ibatis.common.jdbc.ScriptRunner" level="DEBUG" />
	<logger name="com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate"
		value="DEBUG" />
	<logger name="com.apache.ibatis" level="TRACE" />



	<!-- root級別 DEBUG -->
	<root level="debug">
		<!-- 控制檯輸出 -->
		<appender-ref ref="STDOUT" />
	</root>
</configuration>

而後是 logback-spring-prod.xml 和logback-spring-uat.xml,uat環境與prod的只是文件位置不一樣因此只貼一份了,改下路徑就好了,而且生產和測試是不須要控制檯輸出的 否則catalina.out文件就要爆炸了

<?xml version="1.0" encoding="UTF-8"?>

<!-- 從高到地低 OFF 、 FATAL 、 ERROR 、 WARN 、 INFO 、 DEBUG 、 TRACE 、 ALL -->
<!-- 日誌輸出規則 根據當前ROOT 級別,日誌輸出時,級別高於root默認的級別時 會輸出 -->
<!-- 如下 每一個配置的 filter 是過濾掉輸出文件裏面,會出現高級別文件,依然出現低級別的日誌信息,經過filter 過濾只記錄本級別的日誌 -->


<!-- 屬性描述 scan:性設置爲true時,配置文件若是發生改變,將會被從新加載,默認值爲true scanPeriod:設置監測配置文件是否有修改的時間間隔,若是沒有給出時間單位,默認單位是毫秒。當scan爲true時,此屬性生效。默認的時間間隔爲1分鐘。 
	debug:當此屬性設置爲true時,將打印出logback內部日誌信息,實時查看logback運行狀態。默認值爲false。 -->
<configuration scan="true" scanPeriod="60 seconds" debug="false">
	<contextName>d1money-web-ys-ems</contextName>
	
	<!-- 定義日誌文件 輸入位置 -->
	<property name="log_dir" value="/soft/apache-tomcat-8.5.30-ems/logs" />
	<!-- 日誌最大的歷史 30天 -->
	<property name="maxHistory" value="30" />
	<property name="maxFileSize" value="10MB" />


	<!-- ERROR級別日誌 -->
	<!-- 滾動記錄文件,先將日誌記錄到指定文件,當符合某個條件時,將日誌記錄到其餘文件 RollingFileAppender -->
	<appender name="ERROR"
		class="ch.qos.logback.core.rolling.RollingFileAppender">
		<!-- 過濾器,只記錄WARN級別的日誌 -->
		<filter class="ch.qos.logback.classic.filter.LevelFilter">
			<level>ERROR</level>
			<onMatch>ACCEPT</onMatch>
			<onMismatch>DENY</onMismatch>
		</filter>
		<!-- 最經常使用的滾動策略,它根據時間來制定滾動策略.既負責滾動也負責出發滾動 -->
		<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
			
			<!--日誌輸出位置 可相對、和絕對路徑 -->
			<fileNamePattern>
				${log_dir}/app_error.%d{yyyy-MM-dd}.%i.log
			</fileNamePattern>
			<!-- 可選節點,控制保留的歸檔文件的最大數量,超出數量就刪除舊文件假設設置每月滾動,且<maxHistory>是6, 則只保存最近6個月的文件,刪除以前的舊文件。注意,刪除舊文件是,那些爲了歸檔而建立的目錄也會被刪除 -->
			<maxHistory>${maxHistory}</maxHistory>
			<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
				<maxFileSize>${maxFileSize}</maxFileSize>
			</timeBasedFileNamingAndTriggeringPolicy>
			
		</rollingPolicy>
		

		<!-- 按照固定窗口模式生成日誌文件,當文件大於20MB時,生成新的日誌文件。窗口大小是1到3,當保存了3個歸檔文件後,將覆蓋最先的日誌。 
			<rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy"> 
			<fileNamePattern>${log_dir}/%d{yyyy-MM-dd}/.log.zip</fileNamePattern> <minIndex>1</minIndex> 
			<maxIndex>3</maxIndex> </rollingPolicy> -->
		<!-- 查看當前活動文件的大小,若是超過指定大小會告知RollingFileAppender 觸發當前活動文件滾動 <triggeringPolicy 
			class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy"> <maxFileSize>5MB</maxFileSize> 
			</triggeringPolicy> -->

		<encoder>
			<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n</pattern>
		</encoder>
	</appender>



	<!-- WARN級別日誌 appender -->
	<appender name="WARN"
		class="ch.qos.logback.core.rolling.RollingFileAppender">
		<!-- 過濾器,只記錄WARN級別的日誌 -->
		<filter class="ch.qos.logback.classic.filter.LevelFilter">
			<level>WARN</level>
			<onMatch>ACCEPT</onMatch>
			<onMismatch>DENY</onMismatch>
		</filter>
		<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
			<!-- 按天回滾 daily -->
			<fileNamePattern>
				${log_dir}/app_warn.%d{yyyy-MM-dd}.%i.log
			</fileNamePattern>
			<!-- 日誌最大的歷史 30天 -->
			<maxHistory>${maxHistory}</maxHistory>
			<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
				<maxFileSize>${maxFileSize}</maxFileSize>
			</timeBasedFileNamingAndTriggeringPolicy>
		</rollingPolicy>
		<encoder>
			<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n</pattern>
		</encoder>
	</appender>




	<!-- INFO級別日誌 appender -->
	<appender name="INFO"
		class="ch.qos.logback.core.rolling.RollingFileAppender">
		<!-- 過濾器,只記錄INFO級別的日誌 -->
		<filter class="ch.qos.logback.classic.filter.LevelFilter">
			<level>INFO</level>
			<onMatch>ACCEPT</onMatch>
			<onMismatch>DENY</onMismatch>
		</filter>
		<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
			<!-- 按天回滾 daily -->
			<fileNamePattern>
				${log_dir}/app_info.%d{yyyy-MM-dd}.%i.log
			</fileNamePattern>
			<!-- 日誌最大的歷史 30天 -->
			<maxHistory>${maxHistory}</maxHistory>
			<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
				<maxFileSize>${maxFileSize}</maxFileSize>
			</timeBasedFileNamingAndTriggeringPolicy>
		</rollingPolicy>
		<encoder>
			<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n</pattern>
		</encoder>
	</appender>




	<!-- DEBUG級別日誌 appender -->
	<appender name="DEBUG"
		class="ch.qos.logback.core.rolling.RollingFileAppender">
		<!-- 過濾器,只記錄DEBUG級別的日誌 -->
		<filter class="ch.qos.logback.classic.filter.LevelFilter">
			<level>DEBUG</level>
			<onMatch>ACCEPT</onMatch>
			<onMismatch>DENY</onMismatch>
		</filter>
		<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
			<!-- 按天回滾 daily -->
			<fileNamePattern>
				${log_dir}/app_debug.%d{yyyy-MM-dd}.%i.log
			</fileNamePattern>
			<!-- 日誌最大的歷史 30天 -->
			<maxHistory>${maxHistory}</maxHistory>
			<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
				<maxFileSize>${maxFileSize}</maxFileSize>
			</timeBasedFileNamingAndTriggeringPolicy>
		</rollingPolicy>
		<encoder>
			<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n</pattern>
		</encoder>
	</appender>

	<!-- TRACE級別日誌 appender -->
	<appender name="TRACE"
		class="ch.qos.logback.core.rolling.RollingFileAppender">
		<!-- 過濾器,只記錄ERROR級別的日誌 -->
		<filter class="ch.qos.logback.classic.filter.LevelFilter">
			<level>TRACE</level>
			<onMatch>ACCEPT</onMatch>
			<onMismatch>DENY</onMismatch>
		</filter>
		<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
			<!-- 按天回滾 daily -->
			<fileNamePattern>
				${log_dir}/app_trace.%d{yyyy-MM-dd}.%i.log
			</fileNamePattern>
			<!-- 日誌最大的歷史 30天 -->
			<maxHistory>${maxHistory}</maxHistory>
			
			<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
				<maxFileSize>${maxFileSize}</maxFileSize>
			</timeBasedFileNamingAndTriggeringPolicy>
		</rollingPolicy>
		<encoder>
			<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n</pattern>
		</encoder>
	</appender>

	<logger name="java.sql.PreparedStatement" value="DEBUG" />
	<logger name="java.sql.Connection" value="DEBUG" />
	<logger name="java.sql.Statement" value="DEBUG" />
	<logger name="com.ibatis" value="DEBUG" />
	<logger name="com.ibatis.common.jdbc.SimpleDataSource" value="DEBUG" />
	<logger name="com.ibatis.common.jdbc.ScriptRunner" level="DEBUG" />
	<logger name="com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate"
		value="DEBUG" />
	<logger name="com.apache.ibatis" level="TRACE" />

	<!-- root級別 DEBUG -->
	<root level="debug">
		<!-- 文件輸出 -->
		<appender-ref ref="ERROR" />
		<appender-ref ref="INFO" />
		<appender-ref ref="WARN" />
		<appender-ref ref="DEBUG" />
		<appender-ref ref="TRACE" />
	</root>
</configuration>

最後達到的效果是按大小日期生成日誌文件,超過設定大小就會從新生成新文件,由0開始累積。

相關文章
相關標籤/搜索