欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

SpringBoot中l(wèi)ogback日志怎么保存到mongoDB-創(chuàng)新互聯(lián)

本篇內(nèi)容介紹了“SpringBoot中l(wèi)ogback日志怎么保存到mongoDB”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供即墨網(wǎng)站建設(shè)、即墨做網(wǎng)站、即墨網(wǎng)站設(shè)計(jì)、即墨網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、即墨企業(yè)網(wǎng)站模板建站服務(wù),十多年即墨做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

自定義Appender非常簡(jiǎn)單,繼承一下AppenderBase類即可。

可以看到有個(gè)AppenderBase,有個(gè)UnsynchronizedAppenderBase,還有個(gè)AsyncAppenderBase繼承了UnsynchronizedAppenderBase。從名字就能看出來區(qū)別,異步的、普通的、不加鎖的。


我們定義一個(gè)MongoDBAppender繼承UnsynchronizedAppenderBase

public class MongoDBAppender extends 
    UnsynchronizedAppenderBase<ILoggingEvent> { 
 
  @Override 
  protected void append(ILoggingEvent eventObject) { 
    MongoTemplate mongoTemplate = ApplicationContextProvider.getBean(MongoTemplate.class); 
    if (mongoTemplate != null) { 
      final BasicDBObject doc = new BasicDBObject(); 
      doc.append("level", eventObject.getLevel().toString()); 
      doc.append("logger", eventObject.getLoggerName()); 
      doc.append("thread", eventObject.getThreadName()); 
      doc.append("message", eventObject.getFormattedMessage()); 
      mongoTemplate.insert(doc, "log"); 
    } 
  } 
 
}

必須要實(shí)現(xiàn)一個(gè)append方法,這個(gè)方法就是logback輸出日志的地方,日志都保存在eventObject對(duì)象中,我們只需要獲取對(duì)象里的值并做自己的處理即可。


我們可以想象為,系統(tǒng)的ConsoleAppender就是不停的System.out.print(eventObject.getXXX),而FileAppender就是用OutpuptStream輸出到文件里。


我們要做的就是把日志保存到mongo里,Springboot已經(jīng)提供了MongoTemplate模板,需要注意日志輸出是隨著系統(tǒng)啟動(dòng)就開始的,而剛開始時(shí)MongoTemplate還沒有被初始化,是需要等待Spring給MongoTemplate賦值的。所以剛開始時(shí)為null,需要等spring初始化完畢,MongoTemplate才有值。


由于這個(gè)Appender不歸spring管理,所以我采用單獨(dú)獲取bean的方式。其中ApplicationContextProvider如下:


@Component 
public class ApplicationContextProvider implements ApplicationContextAware { 
  private static ApplicationContext context; 
 
  public static ApplicationContext getApplicationContext() { 
    return context; 
  } 
 
  @Override 
  public void setApplicationContext(ApplicationContext ac) 
      throws BeansException { 
    context = ac; 
  } 
 
  public static <T> T getBean(Class<T> tClass) { 
    return context.getBean(tClass); 
  } 
 
  public static <T> T getBean(String name, Class<T> tClass) { 
    return context.getBean(name, tClass); 
  } 
}

上面mongo操作日志入庫(kù)的比較簡(jiǎn)單,字段也沒有用完,大家可以根據(jù)自己希望保存的屬性來設(shè)計(jì)mongo的結(jié)構(gòu),然后入庫(kù)。


pom.xml

<dependency>
      <groupId>org.mongodb</groupId>
      <artifactId>mongo-java-driver</artifactId>
      <version>3.4.2</version>
    </dependency>
    <dependency>
      <groupId>ch.qos.logback</groupId>
      <artifactId>logback-core</artifactId>
      <version>1.1.11</version>
    </dependency>
    <dependency> 
      <groupId>ch.qos.logback</groupId> 
      <artifactId>logback-classic</artifactId> 
      <version>1.1.11</version> 
    </dependency>

在Spring-logback.xml使用也很簡(jiǎn)單


<?xml version="1.0" encoding="UTF-8"?> 
<configuration> 
  <include resource="org/springframework/boot/logging/logback/base.xml" /> 
 
  <appender name="MY_FILE" class="com.example.demo.mongo.MongoDBAppender"> 
  </appender> 
  <!-- 測(cè)試環(huán)境+開發(fā)環(huán)境. 多個(gè)使用逗號(hào)隔開. --> 
  <springProfile name="test,dev"> 
    <logger name="org.springframework.web" level="INFO"> 
      <appender-ref ref="MY_FILE"/> 
    </logger> 
    <logger name="com.example" level="INFO" /> 
  </springProfile> 
 
 
</configuration>

只需要指明appender 的class即可。

“SpringBoot中l(wèi)ogback日志怎么保存到mongoDB”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

文章名稱:SpringBoot中l(wèi)ogback日志怎么保存到mongoDB-創(chuàng)新互聯(lián)
鏈接地址:http://aaarwkj.com/article38/deogpp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、靜態(tài)網(wǎng)站企業(yè)建站、企業(yè)網(wǎng)站制作網(wǎng)站策劃、關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化
玩弄丰满熟妇留守妇女| 日韩欧美精品另类在线| 六月丁香花五月婷婷| 麻豆看片高清在线播放| 男人天堂手机视频在线| 原创国产av剧情精品| 日本少妇入口一区二区| 亚洲午夜精品久久久天堂| 丰满人妻一区二区三区色| 亚洲va久久久噜噜噜久久狠| 欧美精品一区二区亚洲| 人成在线免费视频网站| 欧美日韩另类综合一区| 国产午夜在线影院一区二区| 亚洲国产精品伦理在线看| 青青草免费视频观看在线| 日韩 欧美 国产 亚洲 综合| 亚洲女同中文字幕在线| 中文字幕一区二区精品区| 日韩欧美亚洲国产一区久久精品| 精品国产一区二区日韩91| 亚洲青涩精品一区二区三区| 国产亚洲一区二区三区成人| 久久99国产综合精品女同| 久久免费观看性生活片| 人妻少妇亚洲中文字幕| 国产精品久久亚洲一区二区| 国产精品国产三级国av中文| 日韩一级久久精品理论| 日日添夜夜添天天操| 午夜日韩综合激情视频在线观看| 国产亚洲中文字幕91| 麻豆色视频在线观看免费| 美日韩黄色大片免费看| 91好色视频在线观看| 亚洲天堂av在线播放| 夜夜春国产精品不卡一区二区| 一本久久综合亚洲鲁鲁五月天| 日韩精品熟妻人女亚洲一区| 精品人妻av中文字幕乱| 欧美黄片完整版在线观看|