溫馨提示×

溫馨提示×

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

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

如何使用SpringBoot+Logback實(shí)現(xiàn)鏈路追蹤功能

發(fā)布時間:2021-09-28 11:25:39 來源:億速云 閱讀:166 作者:小新 欄目:編程語言

小編給大家分享一下如何使用SpringBoot+Logback實(shí)現(xiàn)鏈路追蹤功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

一、實(shí)現(xiàn)原理

Spring Boot默認(rèn)使用LogBack日志系統(tǒng),并且已經(jīng)引入了相關(guān)的jar包,所以我們無需任何配置便可以使用LogBack打印日志。

MDC(Mapped Diagnostic Context,映射調(diào)試上下文)是log4j和logback提供的一種方便在多線程條件下記錄日志的功能。

實(shí)現(xiàn)思路是在一個請求開始時,將請求相關(guān)的上下文信息(例如客戶ID、客戶的IP地址、sessionId、請求參數(shù)等)添加到MDC,然后配置好logback-spring.xml,則Logback組件將會在每條日志中打印出存放到MDC的信息,從而實(shí)現(xiàn)一個ID貫穿用戶的所有操作。

二、代碼實(shí)戰(zhàn)

新建一個spring boot項(xiàng)目spring-boot-log,按照下面步驟操作。

新建日志攔截器

日志攔截器在請求開始獲取用戶的sessionId,當(dāng)然也可以生成一個UUID,生成后存放到MDC中。

SessionInterceptor代碼如下:

/** * 日志攔截器 * @Author: Java碎碎念 * */public class SessionInterceptor extends HandlerInterceptorAdapter {  /**   * 會話ID   */  private final static String SESSION_KEY = "sessionId";  @Override  public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,              Object arg2, ModelAndView arg3) throws Exception {  }  @Override  public boolean preHandle(HttpServletRequest request,               HttpServletResponse response, Object handler) throws Exception {//    String token = UUID.randomUUID().toString().replaceAll("-","");    //本例測試使用sessionId,也可以使用UUID等    String token = request.getSession().getId();    MDC.put(SESSION_KEY, token);    return true;  }  @Override  public void afterCompletion(HttpServletRequest arg0,                HttpServletResponse arg1, Object arg2, Exception arg3)      throws Exception {    // 刪除    MDC.remove(SESSION_KEY);  }}

新建配置類

新建InterceptorConfig,注冊剛才的日志攔截器。

InterceptorConfig代碼如下:

@Configurationpublic class InterceptorConfig implements WebMvcConfigurer {  @Bean  public SessionInterceptor getSessionInterceptor() {    return new SessionInterceptor();  }  @Override  public void addInterceptors(InterceptorRegistry registry) {    registry.addInterceptor(getSessionInterceptor()).addPathPatterns("/*");  }}

修改logback-spring.xml

配置logback-spring.xml,獲取日志攔截器添加的sessionId并打印到日志中,配置文件中獲取方式如下:

%X{sessionId}

本例中打印sessionId到控制臺和文件,完整配置如下:

<?xml version="1.0" encoding="UTF-8"?><configuration>  <property name="log.base" value="./log/logback"/>  <appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">    <encoder>      <pattern> %date [%thread] [%X{sessionId}] %-5level %logger{80} - %msg%n      </pattern>    </encoder>  </appender>  <appender name="logfile"       class="ch.qos.logback.core.rolling.RollingFileAppender">    <File>${log.base}.log</File>    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">      <FileNamePattern>${log.base}.%d{yyyy -MM-dd}.log.zip</FileNamePattern>    </rollingPolicy>    <encoder>      <pattern> %date [%thread] [%X{sessionId}] %-5level %logger{80} - %msg%n      </pattern>    </encoder>  </appender>  <logger name="com.sample" level="TRACE"/>  <root>    <level value="INFO"/>    <appender-ref ref="stdout"/>    <appender-ref ref="logfile"/>  </root></configuration>

添加controller

新建TestLogController,打印日志。

代碼如下:

@RestControllerpublic class TestLogController {  Logger log = LoggerFactory.getLogger(getClass());  /**   * 測試登錄   */  @RequestMapping(value = "/testLogin")  public String testLogin() {    log.info("用戶登錄成功!");    return "ok";  }  /**   * 測試下單   */  @RequestMapping(value = "/testNewOrder")  public String testNewOrder() {    log.info("用戶創(chuàng)建了訂單!");    log.info("請求完成,返回ok!");    return "ok";  }  /**   * 測試購買   */  @RequestMapping(value = "/testPay")  public String testPay() {    log.info("用戶付款!");    return "ok";  }}

三、測試

打開瀏覽器連續(xù)訪問接口testLogin、testNewOrder和testPay,模擬用戶登錄、下單、付款操作,控制臺和文件中打印的日志中已經(jīng)包含了sessonId信息,打印的結(jié)果如下:

[http-nio-8888-exec-1] [CB8E7DB250A31F2BE6C05B30633B9A95] INFO com.example.springbootlog.controller.TestLogController - 用戶登錄成功![http-nio-8888-exec-2] [CB8E7DB250A31F2BE6C05B30633B9A95] INFO com.example.springbootlog.controller.TestLogController - 用戶創(chuàng)建了訂單![http-nio-8888-exec-2] [CB8E7DB250A31F2BE6C05B30633B9A95] INFO com.example.springbootlog.controller.TestLogController - 請求完成,返回ok![http-nio-8888-exec-3] [CB8E7DB250A31F2BE6C05B30633B9A95] INFO com.example.springbootlog.controller.TestLogController - 用戶付款!

以上是“如何使用SpringBoot+Logback實(shí)現(xiàn)鏈路追蹤功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI