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

springboot使用logback日志級(jí)別打印控制操作得示例-創(chuàng)新互聯(lián)

小編給大家分享一下spring boot使用logback日志級(jí)別打印控制操作得示例,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

為開(kāi)原等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及開(kāi)原網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為做網(wǎng)站、網(wǎng)站設(shè)計(jì)、開(kāi)原網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!

因?yàn)楣緲I(yè)務(wù)需要,需要把性能日志和業(yè)務(wù)日志分開(kāi)打印,用elk收集處理,所以需要對(duì)不同的業(yè)務(wù)的日志,打印到不同文件。

使用的是spring boot自帶的logback。

首先在yml文件配置logback.xml文件,默認(rèn)會(huì)從resources下找logback.xml文件,找不到會(huì)從yml文件中找logging.config下的指定文件。

logging:
 level: DEBUG
 config: classpath:logback.xml

logback.xml是logback的配置文件,可以設(shè)置打印文件的路徑,格式,過(guò)濾打印的級(jí)別等等,我們來(lái)看一下logback.xml文件。

<?xml version="1.0" encoding="UTF-8"?>
<!--根標(biāo)簽-->
<configuration>
  <!--設(shè)置變量,name為變量名,value為值,可以使用${變量名}方式使用-->
  <property name="APPDIR" value="log" />
  <property name="LOG_HOME" value="/var/app/logs" />
  <property name="APPNAME" value="app_test" />
  <property name="MDC_LOG_PATTERN"
  value="%d{yyyy-MM-dd'T'HH:mm:ss.SSS} %p app_test %t %logger{50} [line:%L %msg]%n"></property> 
 
  <!-- 性能日志記錄器,日期滾動(dòng)記錄 -->
  <!--當(dāng)一個(gè)記錄日志的事件被發(fā)起時(shí),logback 會(huì)將這個(gè)事件發(fā)送給 appender-->
  <!--RollingFileAppender,滾動(dòng)記錄文件,先將日志記錄到指定文件,當(dāng)符合某個(gè)條件時(shí),將日志記錄到其他文件-->
  <appender name="performanceAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <!-- 記錄的日志文件的路徑及文件名 -->
    <file>${LOG_HOME}/${APPNAME}/performanceLog/${APPNAME}.log</file>
    <!-- 日志記錄器的滾動(dòng)策略,按日期,按大小記錄 -->
    <!--TimeBasedRollingPolicy 實(shí)現(xiàn)的是基于時(shí)間的分包策略,分包間隔是根據(jù)fileNamePattern中指定的事件最小單位-->
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <!-- 歸檔的日志文件的路徑,例如今天是2018-12-19日志,當(dāng)前寫的日志文件路徑為file節(jié)點(diǎn)指定,可以將此文件與file指定文件路徑設(shè)置為不同路徑,從而將當(dāng)前日志文件或歸檔日志文件置不同的目錄。
        而2018-12-01的日志文件在由fileNamePattern指定。%d{yyyy-MM-dd}指定日期格式,%i指定索引 -->
      <fileNamePattern>${LOG_HOME}/${APPNAME}/performanceLog/${APPNAME}-%d{yyyyMMdd}.%i.log</fileNamePattern>
      <!-- 除按日志記錄之外,還配置了日志文件不能超過(guò)50Mb,若超過(guò)50Mb,日志文件會(huì)以索引0開(kāi)始, 命名日志文件,例如app_test-20181219.0.log -->
      <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
        <!--較大50mb-->
        <maxFileSize>50MB</maxFileSize>
      </timeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>
    <!-- 追加方式記錄日志 -->
    <append>true</append>
    <!-- 日志文件的格式和編碼 -->
    <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
      <pattern>%d{yyyy/MM/dd' 'HH:mm:ss.SSS} %X{req.requestId}[line:%L %msg] %n</pattern>
      <charset>utf-8</charset>
    </encoder>
     <!--此日志文件只記錄info級(jí)別的-->
    <!--filter是日志過(guò)濾器-->
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
      <!--過(guò)濾級(jí)別-->
      <level>info</level>
      <onMatch>ACCEPT</onMatch>
      <onMismatch>DENY</onMismatch>
    </filter>
  </appender> 
 
  <!-- 運(yùn)行日志記錄器,日期滾動(dòng)記錄 -->
  <appender name="bizAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <!-- 正在記錄的日志文件的路徑及文件名 -->
    <file>${LOG_HOME}/${APPNAME}/bizLog/${APPNAME}.log</file>
    <!-- 日志記錄器的滾動(dòng)策略,按日期,按大小記錄-->
 
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      
      <fileNamePattern>${LOG_HOME}/${APPNAME}/bizLog/${APPNAME}-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
      <!-- 除按日志記錄之外,還配置了日志文件不能超過(guò)50M,若超過(guò)50M,日志文件會(huì)以索引0開(kāi)始, 命名日志文件,例如bizlog-biz-20181219.0.log -->
      <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
        <maxFileSize>50MB</maxFileSize>
        <!--保存時(shí)間3天-->
        <!--<MaxHistory>3</MaxHistory>-->
      </timeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>
    <!-- 追加方式記錄日志 -->
    <append>true</append>
    <!-- 日志文件的格式 -->
    <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
      <pattern>%d{yyyy/MM/dd' 'HH:mm:ss.SSS} %X{req.requestId}[line:%L %msg] %n</pattern>
      <charset>utf-8</charset>
    </encoder>
    <!-- 此日志文件只記錄info級(jí)別的 -->
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
      <level>info</level>
      <level>error</level>
      <!--<onMatch>ACCEPT</onMatch>-->
      <!--<onMismatch>DENY</onMismatch>-->
    </filter>
  </appender>
 
  <!--ConsoleAppender是打印到控制臺(tái)的-->
  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <!--encoder 默認(rèn)配置為PatternLayoutEncoder-->
    <encoder>
      <pattern>${MDC_LOG_PATTERN}</pattern>
      <charset>utf-8</charset>
    </encoder>
    <!--此日志appender是為開(kāi)發(fā)使用,只配置最底級(jí)別,控制臺(tái)輸出的日志級(jí)別是大于或等于此級(jí)別的日志信息-->
    <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
      <level>all</level>
    </filter>
  </appender>
 
  <!--使用LoggerFactory.getLogger("performanceLogger") 使用這個(gè)logger-->
  <logger name="performanceLogger" additivity="false">
    <!--使用哪一個(gè)Appender-->
    <appender-ref ref="performanceAppender" />
 
  </logger>
  <!--根loger。只有一個(gè)level屬性,應(yīng)為已經(jīng)被命名為"root".-->
  <root level="info">
    <appender-ref ref="bizAppender" />
    <appender-ref ref="STDOUT" />
 
  </root> 
</configuration>

<configuration>:根標(biāo)簽,所有標(biāo)簽都在里面。

<property>:屬性標(biāo)簽,設(shè)置變量,name為變量名,value為值,可以使用${變量名}方式使用。

<appender>:當(dāng)一個(gè)記錄日志的事件被發(fā)起時(shí),logback 會(huì)將這個(gè)事件發(fā)送給 appender,經(jīng)常使用的有ch.qos.logback.core.ConsoleAppender和ch.qos.logback.core.rolling.RollingFileAppender,ConsoleAppender是打印到控制臺(tái)的,RollingFileAppender是滾動(dòng)記錄文件,先將日志記錄到指定文件,當(dāng)符合某個(gè)條件時(shí),將日志記錄到其他文件。

<file>:在<appender>中使用,記錄的日志文件的路徑及文件名。

<rollingPolicy>:分包策略,就是前一天日志的存儲(chǔ)文件名,大小,壓縮格式,存放天數(shù)。ch.qos.logback.core.rolling.TimeBasedRollingPolicy:實(shí)現(xiàn)的是基于時(shí)間的分包策略,分包間隔是根據(jù)<fileNamePattern>中指定的事件最小單位。

<fileNamePattern>:存放日志的路徑和名稱。

<maxFileSize>:每個(gè)文件較大文件。

<encoder>:日志文件的格式和編碼。

<charset>:日志編碼格式。

<pattern>:設(shè)置日志打印格式。

<filter>:日志過(guò)濾器。

<level>:日志過(guò)濾級(jí)別,TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF。

<logger>:使用LoggerFactory.getLogger("performanceLogger") 使用這個(gè)logger。

<root>:根loger。只有一個(gè)level屬性,應(yīng)為已經(jīng)被命名為"root"。

%d{yyyy/MM/dd' 'HH:mm:ss.SSS}:是對(duì)時(shí)間格式化,2018/12/19 17:31:17.126

%X{ req.requestId}:在MDC類中添加req.requestId參數(shù),即可在logback.xml中使用,后面講MDC類。

%p:打印出日志級(jí)別信息,如:INFO,ERROR等錯(cuò)誤級(jí)別。

%t:是打印出線程或者哪個(gè)類打印出的日志。

%L:打印出當(dāng)前行數(shù)。

%msg:就是日志信息啦。就是logger.info("xxx"),xxx就是%msg。

%n:換行。

MDC

是為了便于我們?cè)\斷線上問(wèn)題而出現(xiàn)的方法工具類。

public class MDC {
 //Put a context value as identified by key
 //into the current thread's context map.
 public static void put(String key, String val);
 
 //Get the context identified by the key parameter.
 public static String get(String key);
 
 //Remove the context identified by the key parameter.
 public static void remove(String key);
 
 //Clear all entries in the MDC.
 public static void clear();
}

基本使用

MDC.put("req.requestId", uuid);
MDC.put("req.remoteHost", request.getRemoteHost());
<pattern>%d{yyyy/MM/dd' 'HH:mm:ss.SSS} %X{req.requestId}[line:%L %msg] %n</pattern>

在logback.xml中可使用%X{req.requestId},得到uuid。

打印到不同文件

private final static Logger performanceLogger = LoggerFactory.getLogger("performanceLogger");

這樣就可以使用logback.xml里<logger>里的performanceLogger,performanceLogger引用的是performanceAppender。

private static final Logger logger = LoggerFactory.getLogger(Class.class);

這樣使用的就是logback.xml里的<root>標(biāo)簽里的bizAppender。

這樣就基本實(shí)現(xiàn)了分不同業(yè)務(wù)邏輯打印到不同文件了。

補(bǔ)充:Springboot 使用logback將各級(jí)別日志分別輸出到不同路徑

SpringBoot默認(rèn)已經(jīng)依賴了部分日志框架(如Logback),且其中推薦使用的也是Logback,所以本次項(xiàng)目中我們將通過(guò)新增Logback日志的配置,將各級(jí)別日志分別輸出到不同路徑。

SpringBoot已經(jīng)依賴了Logback,所以不需要手動(dòng)添加依賴。

SpringBoot會(huì)自動(dòng)識(shí)別和讀取resources目錄下新建logback-spring.xml,所以不需要在application.yml進(jìn)行其他的配置了。

配置文件具體如下:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <!-- 項(xiàng)目名稱 -->
  <property name="PROJECT_NAME" value="XXXXX" />
 
  <!-- 文件輸出格式 -->
  <property name="PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n"/>
  <!-- 輸出文件路徑 -->
  <property name="OPEN_FILE_PATH" value="logs/manager"/>
 
  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
      <pattern>${PATTERN}</pattern>
      <charset>UTF-8</charset>
    </encoder>
  </appender>
 
  <!-- ch.qos.logback.core.rolling.RollingFileAppender 文件日志輸出 -->
  <appender name="OPEN-FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <!--不能有這項(xiàng)配置!?。。。?->
    <!--<Encoding>UTF-8</Encoding>-->
    <!--<File>${OPEN_FILE_PATH}/zqread.log</File>-->
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <!--日志文件輸出的文件名-->
      <FileNamePattern>${OPEN_FILE_PATH}/all/zqread.%d{yyyy-MM-dd}-%i.log</FileNamePattern>
      <!--日志文件保留天數(shù)-->
      <MaxHistory>30</MaxHistory>
      <TimeBasedFileNamingAndTriggeringPolicy
          class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
        <!--日志文件較大的大小-->
        <MaxFileSize>10MB</MaxFileSize>
      </TimeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>
 
    <layout class="ch.qos.logback.classic.PatternLayout">
      <pattern>${PATTERN}</pattern>
    </layout>
  </appender>
 
  <!--輸出到debug-->
  <appender name="debug" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <FileNamePattern>${OPEN_FILE_PATH}/debug/zqread.%d{yyyy-MM-dd}-%i.log</FileNamePattern>
      <MaxHistory>30</MaxHistory>
      <TimeBasedFileNamingAndTriggeringPolicy
          class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
        <MaxFileSize>10MB</MaxFileSize>
      </TimeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>
    <append>true</append>
    <encoder>
      <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %contextName [%thread] %-5level %logger{36} - %msg%n</pattern>
      <charset>utf-8</charset>
    </encoder>
    <filter class="ch.qos.logback.classic.filter.LevelFilter"><!-- 只打印DEBUG日志 -->
      <level>DEBUG</level>
      <onMatch>ACCEPT</onMatch>
      <onMismatch>DENY</onMismatch>
    </filter>
  </appender>
 
  <!--輸出到info-->
  <appender name="info" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <FileNamePattern>${OPEN_FILE_PATH}/info/zqread.%d{yyyy-MM-dd}-%i.log</FileNamePattern>
      <MaxHistory>30</MaxHistory>
      <TimeBasedFileNamingAndTriggeringPolicy
          class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
        <MaxFileSize>10MB</MaxFileSize>
      </TimeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>
    <append>true</append>
    <encoder>
      <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %contextName [%thread] %-5level %logger{36} - %msg%n</pattern>
      <charset>utf-8</charset>
    </encoder>
    <filter class="ch.qos.logback.classic.filter.LevelFilter"><!-- 只打印INFO日志 -->
      <level>INFO</level>
      <onMatch>ACCEPT</onMatch>
      <onMismatch>DENY</onMismatch>
    </filter>
  </appender>
 
  <!--輸出到error-->
  <appender name="error" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <FileNamePattern>${OPEN_FILE_PATH}/error/zqread.%d{yyyy-MM-dd}-%i.log</FileNamePattern>
      <MaxHistory>30</MaxHistory>
      <TimeBasedFileNamingAndTriggeringPolicy
          class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
        <MaxFileSize>10MB</MaxFileSize>
      </TimeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>
    <append>true</append>
    <encoder>
      <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %contextName [%thread] %-5level %logger{36} - %msg%n</pattern>
      <charset>utf-8</charset>
    </encoder>
    <filter class="ch.qos.logback.classic.filter.LevelFilter"><!-- 只打印ERROR日志 -->
      <level>ERROR</level>
      <onMatch>ACCEPT</onMatch>
      <onMismatch>DENY</onMismatch>
    </filter>
  </appender>
 
  <!--輸出到warn-->
  <appender name="warn" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <FileNamePattern>${OPEN_FILE_PATH}/warn/zqread.%d{yyyy-MM-dd}-%i.log</FileNamePattern>
      <MaxHistory>30</MaxHistory>
      <TimeBasedFileNamingAndTriggeringPolicy
          class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
        <MaxFileSize>10MB</MaxFileSize>
      </TimeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>
    <append>true</append>
    <encoder>
      <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %contextName [%thread] %-5level %logger{36} - %msg%n</pattern>
      <charset>utf-8</charset>
    </encoder>
    <filter class="ch.qos.logback.classic.filter.LevelFilter"><!-- 只打印WARN日志 -->
      <level>WARN</level>
      <onMatch>ACCEPT</onMatch>
      <onMismatch>DENY</onMismatch>
    </filter>
  </appender>
 
  <root level="info">
    <appender-ref ref="STDOUT"/>
    <appender-ref ref="OPEN-FILE"/>
    <appender-ref ref="debug" />
    <appender-ref ref="info" />
    <appender-ref ref="error" />
    <appender-ref ref="warn" />
  </root>
</configuration>

以上是“spring boot使用logback日志級(jí)別打印控制操作得示例”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

分享文章:springboot使用logback日志級(jí)別打印控制操作得示例-創(chuàng)新互聯(lián)
文章出自:http://aaarwkj.com/article30/pjgso.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)關(guān)鍵詞優(yōu)化、品牌網(wǎng)站建設(shè)、標(biāo)簽優(yōu)化、電子商務(wù)、手機(jī)網(wǎng)站建設(shè)

廣告

聲明:本網(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í)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
亚洲精品国产精品粉嫩av| 久久人妻一区二区三区免费密臀| 日本人妻系列在线播放| 国产剧情av在线资源| 欧美日韩精品国产精品| 亚洲黄色成人免费观看| 92国产精品午夜福利| 成人av久久一区二区三区| 中文字幕午夜av福利| 999久久免费精品国产| 日韩激情av中文字幕| 欧美亚洲精品一区二区三区| 97色伦综合在线欧美视频| 97成品视频在线播放| 久久综合视频大片视频| 免费啪啪视频一区二区| 国语对白精品视频在线| 国产传媒在线视频观看| 精品国产一区二区日韩91| 欧美午夜精品福利在线观看| 小草少妇视频免费看视频| 国产亚洲综合久久系列| 亚洲欧美日韩性生活视频| 欧美人与性禽动交情品| 亚洲国产传媒在线观看| 一区二区三区福利视频在线观看 | 日本一区二区日本一区| 亚洲欧美国产日韩天堂区| 国产亚洲一区二区三区成人| 蜜臀视频网站在线观看| 亚洲欧美天堂一区二区| 91制片国产在线观看| 久久re这里只有精品6| 麻豆人妻少妇精品毛片| 日本东京热免一区二区| 久久久久久久精品久久| 人妻猛烈进入中文字幕| 国产精品大全中文字幕| 日本一区二区三区高清不卡| 视频二区国产欧美日韩| 亚洲女人下体毛茸茸视频|