中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么修改覆蓋spring boot默認日志策略logback

發布時間:2021-02-08 09:35:31 來源:億速云 閱讀:431 作者:小新 欄目:編程語言

這篇文章主要介紹了怎么修改覆蓋spring boot默認日志策略logback,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

Spring Boot在所有內部日志中使用Commons Logging,但是默認配置也提供了對常用日志的支持,如:Java Util Logging,Log4J, Log4J2和Logback。每種Logger都可以通過配置使用控制臺或者文件輸出日志內容。

默認日志Logback

SLF4J——Simple Logging Facade For Java,它是一個針對于各類Java日志框架的統一Facade抽象。Java日志框架眾多——常用的有java.util.logging, log4j, logback,commons-logging, Spring框架使用的是Jakarta Commons Logging API (JCL)。而SLF4J定義了統一的日志抽象接口,而真正的日志實現則是在運行時決定的——它提供了各類日志框架的binding。

Logback是log4j框架的作者開發的新一代日志框架,它效率更高、能夠適應諸多的運行環境,同時天然支持SLF4J。

默認情況下,Spring Boot會用Logback來記錄日志,并用INFO級別輸出到控制臺。在運行應用程序和其他例子時,你應該已經看到很多INFO級別的日志了。

springboot初始化了日志的默認實現,只要我們在配置文件添加對應的配置即可。

比如

logging:
 file: logs/application-debug.log
 pattern:
 console: "%d %-5level %logger : %msg%n"
 file: "%d %-5level [%thread] %logger : %msg%n"
 level:
 org.springframework.web: ERROR
 com.howtodoinjava: INFO
 org.hibernate: ERROR

可以指定日志文件名,覆蓋默認的pattern,指定不同日志級別。

但依舊有很多局限性。比如,默認的文件方案是:

E:\maven\repository\org\springframework\boot\spring-boot\1.5.13.RELEASE\spring-boot-1.5.13.RELEASE.jar!\org\springframework\boot\logging\logback\file-appender.xml

 <appender name="FILE"
  class="ch.qos.logback.core.rolling.RollingFileAppender">
  <encoder>
   <pattern>${FILE_LOG_PATTERN}</pattern>
  </encoder>
  <file>${LOG_FILE}</file>
  <rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
   <fileNamePattern>${LOG_FILE}.%i</fileNamePattern>
  </rollingPolicy>
  <triggeringPolicy
   class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
   <MaxFileSize>10MB</MaxFileSize>
  </triggeringPolicy>
 </appender>

只是超過10m就生成一個新文件。而我們還遇到過日志把磁盤打滿的情況。肯定需要定時清理,還想要按照日期生成文件。這樣,僅僅配置文件是不夠的,需要我們自己定義。

自定義

實現自定義就是在resource下新增logback-spring.xml, 然后編寫我們的配置方案。就是完全跳過spring的默認配置了。但我又想偷懶,還想用spring的配置,但只是修改個別,比如file。

spring默認配置文件 E:\maven\repository\org\springframework\boot\spring-boot\1.5.13.RELEASE\spring-boot-1.5.13.RELEASE.jar!\org\springframework\boot\logging\logback\base.xml

我們只要

<include resource="org/springframework/boot/logging/logback/base.xml"/>

就可以拿過來直接用。

最初我也是這樣做的,但后面發現有些東西是不能覆蓋的。比如內置的日志文件名,所以,最后把base里的內容單獨抽離出來用了。

logback-spring.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds" debug="false">

 <springProperty scope="context" name="appName" source="spring.application.name"
 defaultValue="application"/>
 <springProperty scope="context" name="log.path" source="logging.path"
 defaultValue="logs"/>
 <springProperty scope="context" name="logstashurl" source="logstash.url"
 defaultValue="localhost:4560"/>

 <!--<include resource="org/springframework/boot/logging/logback/base.xml"/>-->
 <include resource="org/springframework/boot/logging/logback/defaults.xml" />
 <property name="LOG_FILE" value="${LOG_FILE:-${LOG_PATH:-${LOG_TEMP:-${java.io.tmpdir:-/tmp}}}/spring.log}"/>
 <include resource="org/springframework/boot/logging/logback/console-appender.xml" />

 <!--輸出到文件-->
 <appender name="TIME_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
 <!--<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">-->
 <!-- <fileNamePattern>${LOG_FILE}.%d{yyyy-MM-dd}.log</fileNamePattern>-->
 <!-- <maxHistory>7</maxHistory>-->
 <!--</rollingPolicy>-->
 <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
  <!-- daily rollover -->
  <fileNamePattern>${LOG_FILE}.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
  <maxHistory>7</maxHistory>
  <maxFileSize>100MB</maxFileSize>
  <totalSizeCap>1GB</totalSizeCap>
 </rollingPolicy>
 <encoder>
  <!--<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} ${appName} %X{req.remoteHost} %X{req.requestURI} %X{req.userAgent} %X{req.method} - [%thread] %-5level %logger{36} - %msg%n</pattern>-->
  <pattern>${FILE_LOG_PATTERN}</pattern>
 </encoder>
 </appender>

 <!-- 輸出到logstash-->
 <appender name="LOGSTASH" class="net.logstash.logback.appender.LogstashTcpSocketAppender">
 <destination>${logstashurl}</destination>
 <encoder charset="UTF-8" class="net.logstash.logback.encoder.LogstashEncoder"/>
 </appender>

 <root level="INFO">
 <appender-ref ref="CONSOLE"/>
 <appender-ref ref="TIME_FILE"/>
 </root>


 <springProfile name="dev">
 <logger name="com.test.demo.mapper" level="DEBUG">
 </logger>
 </springProfile>
 <springProfile name="local, test, prod">
 <root level="warn">
  <appender-ref ref="LOGSTASH"/>
 </root>
 </springProfile>
</configuration>

同時,需要讀取配置文件, 配置文件依舊生效

logging:
 path: logs
 file: ${logging.path}/${spring.application.name}

這里,include拿到spring默認配置,但移除了base里的root配置,去掉了file。并自定義file。file規則是保存7天,每100m分一個文件,總大小不超過1G。

 <springProperty scope="context" name="appName" source="spring.application.name"
 defaultValue="application"/>
 <springProperty scope="context" name="log.path" source="logging.path"
 defaultValue="logs"/>
 <springProperty scope="context" name="logstashurl" source="logstash.url"
 defaultValue="localhost:4560"/>

這一塊配置并沒有使用,只是放這里備份。logback里想要使用spring的配置文件的變量,只能通過這種方式讀取。因為我配置了logstash,需要讀取logstash的url,所以這樣做。

感謝你能夠認真閱讀完這篇文章,希望小編分享的“怎么修改覆蓋spring boot默認日志策略logback”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

庆阳市| 若羌县| 泰州市| 本溪市| 漳平市| 陵水| 普兰店市| 福海县| 台北县| 雷州市| 沙河市| 澎湖县| 镶黄旗| 老河口市| 杂多县| 桦川县| 高阳县| 临江市| 和政县| 拜泉县| 湘阴县| 临西县| 新乐市| 靖宇县| 长春市| 广平县| 新平| 呼图壁县| 蓝田县| 宁明县| 山东省| 甘洛县| 大竹县| 北安市| 邻水| 武功县| 高阳县| 山西省| 昌平区| 江西省| 博野县|