国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > Java > 正文

SpringBoot之logback-spring.xml不生效的解決方法

2024-07-13 10:16:24
字體:
來源:轉載
供稿:網友

一、前言

做新應用就是這樣,會遇到各種問題,昨天剛解決了加載某一個類時候拋出了 class is not visible from class loader 的問題,今天就有遇到了日志文件找不到的問題,還是和二方庫有關的,下面就一一道來。

二、問題產生

正常情況下在  src/main/resources 目錄放下  logback-spring.xml 的配置文件(使用logback日志系統),如下圖

Spring,Boot,logback-spring.xml,logback,spring.xml

application.properties里面設置  spring.application.name=spring-boot-demo-application

引入了一個二方包,二方包里面有 logback.xml

按照上面配置,運行后正常情況下我們希望在 user.home/spring-boot-demo-application/logs 目錄應該有 applicaiton.log 日志文件,然而并沒有,連 spring-boot-demo-application 這個文件夾都沒有生成。

三、問題分析

那么我們就去看看日志系統是如何查找并解析日志配置文件的,SpringBoot中是使用LoggingApplicationListener這個類來進行日志系統的初始化的。LoggingApplicationListener實現了ApplicationListener接口,那么我們通過時序圖看LoggingApplicationListener的onApplicationEvent方法做了啥:

Spring,Boot,logback-spring.xml,logback,spring.xml

代碼(8)查找標準日志配置文件,什么是標準那,那么就看代碼(9)的代碼:

protected String[] getStandardConfigLocations() {  return new String[] { "logback-test.groovy", "logback-test.xml", "logback.groovy",    "logback.xml" }; }

像 "logback-test.groovy", "logback-test.xml", "logback.groovy","logback.xml" 這些是標準的。

那么具體怎么查找那,要看代碼(10):

private String findConfig(String[] locations) {  for (String location : locations) {   ClassPathResource resource = new ClassPathResource(location,     this.classLoader);   if (resource.exists()) {    return "classpath:" + location;   }  }  return null; }

可知使用ClassPathResource類去查找,下面看ClassPathResource的exists方法:

public boolean exists() {  return (resolveURL() != null); }  protected URL resolveURL() {  if (this.clazz != null) {   return this.clazz.getResource(this.path);  }  else if (this.classLoader != null) {   return this.classLoader.getResource(this.path);  }  else {   return ClassLoader.getSystemResource(this.path);  } }

可知是使用 this.classLoader.getResource(this.path); 去查找這里classLoader為AppClassloader。

如果代碼(8)沒有查找到配置,則執行點(12),代碼12邏輯和代碼(8)類似只是查找文件名字不一樣,下面看下:

protected String[] getSpringConfigLocations() {  String[] locations = getStandardConfigLocations();  for (int i = 0; i < locations.length; i++) {   String extension = StringUtils.getFilenameExtension(locations[i]);   locations[i] = locations[i].substring(0,     locations[i].length() - extension.length() - 1) + "-spring."     + extension;  }  return locations; }

可知是在getStandardConfigLocations的文件名上拼接spring,拼接后的文件名為:

“` “logback-test-spring.groovy”, “logback-test-spring.xml”, “logback-spring.groovy”,”logback-spring.xml” “

綜上所述SpringBoot首先去查找標準的日志配置文件,如果找不到在去找拼接Spring的配置的文件。

那么上面我們說了應用中是引入了一個含有logback.xml的jar包,而這個jar包也是使用appclassloader加載的,所以在執行步驟(8)的時候找到了jar包里面的logback.xml,所以就不會再去執行步驟(12)來找我們自定義的logback-spring.xml了。

四、問題解決

方案一,修改我們的配置文件為logback.xml,這樣在步驟(8)的時候會首先查找logback.xml,應該是可以找到的。

方案二、避免二方包里面含有logback.xml,這種情況下,無論我們自己的配置是logback-spring.xml還是logback.xml都不會有問題。

五、總結

日常開發中二方包里面不要帶有日志配置文件,二方庫中使用日志一般都是使用代碼創建的方式。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 繁昌县| 时尚| 阜城县| 内丘县| 邢台县| 定安县| 镇远县| 德保县| 威远县| 巫山县| 巴彦淖尔市| 介休市| 南充市| 思南县| 阿尔山市| 海口市| 玉门市| 齐齐哈尔市| 章丘市| 平江县| 都匀市| 白银市| 元江| 阿图什市| 青冈县| 宽城| 贡嘎县| 五家渠市| 台中县| 文昌市| 启东市| 四平市| 鞍山市| 高碑店市| 聂拉木县| 镇平县| 长阳| 富裕县| 封丘县| 洱源县| 拉孜县|