欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot+Logback實現(xiàn)一個簡單的鏈路追蹤功能

 更新時間:2019年10月31日 13:37:39   作者:java_lover  
Spring Boot默認使用LogBack日志系統(tǒng),并且已經(jīng)引入了相關(guān)的jar包,所以我們無需任何配置便可以使用LogBack打印日志。這篇文章主要介紹了SpringBoot+Logback實現(xiàn)一個簡單的鏈路追蹤功能,需要的朋友可以參考下

最近線上排查問題時候,發(fā)現(xiàn)請求太多導致日志錯綜復雜,沒辦法把用戶在一次或多次請求的日志關(guān)聯(lián)在一起,所以就利用SpringBoot+Logback手寫了一個簡單的鏈路追蹤,下面詳細介紹下。

一、實現(xiàn)原理

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

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

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

二、代碼實戰(zhàn)

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

新建日志攔截器

日志攔截器在請求開始獲取用戶的sessionId,當然也可以生成一個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代碼如下:

@Configuration
public 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,打印日志。

代碼如下:

@RestController
public 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手寫一個簡單的鏈路追蹤功能已經(jīng)全部實現(xiàn),有問題歡迎留言溝通哦!

完整源碼地址: https://github.com/suisui2019/springboot-study

總結(jié)

以上所述是小編給大家介紹的SpringBoot+Logback實現(xiàn)一個簡單的鏈路追蹤功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • Redis集群原理詳細分析

    Redis集群原理詳細分析

    Redis集群實現(xiàn)了對Redis的水平擴容,即啟動N個redis節(jié)點,將整個數(shù)據(jù)庫分布存儲在這N個節(jié)點中,每個節(jié)點存儲總數(shù)據(jù)的1/N。Redis集群通過分區(qū)來提供一定程度的可用,即使集群中有一部分節(jié)點失效或者無法進行通訊,集群也可以繼續(xù)處理命令請求
    2022-12-12
  • Kafka之kafka-topics.sh的使用解讀

    Kafka之kafka-topics.sh的使用解讀

    這篇文章主要介紹了Kafka之kafka-topics.sh的使用解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 一文帶你弄懂Maven拉包(拉取依賴包)原理

    一文帶你弄懂Maven拉包(拉取依賴包)原理

    業(yè)務需求開發(fā)的時候,我們總是會遇到拉不到依賴包的情況,此時如果不清楚 Maven 拉取依賴包的原理,那么很可能找不到問題所在,今天小編就帶大家了解下 Maven 拉包的原理,讓你在遇到問題的時候能快速解決,需要的朋友可以參考下
    2023-07-07
  • Java IO文件過濾器對命令設計模式的使用

    Java IO文件過濾器對命令設計模式的使用

    java io流里面使用到了很多的設計模式,最典型的就是裝飾模式,還有命令模式,下面分兩部分來講Java IO文件過濾器對命令設計模式的使用,一起看看吧
    2017-06-06
  • Java 數(shù)據(jù)類型及類型轉(zhuǎn)換的互相轉(zhuǎn)換實例代碼

    Java 數(shù)據(jù)類型及類型轉(zhuǎn)換的互相轉(zhuǎn)換實例代碼

    這篇文章主要介紹了Java 數(shù)據(jù)類型及類型轉(zhuǎn)換的互相轉(zhuǎn)換實例代碼,需要的朋友可以參考下
    2020-10-10
  • Spring bean對象實例化實現(xiàn)過程圖解

    Spring bean對象實例化實現(xiàn)過程圖解

    這篇文章主要介紹了Spring bean對象實例化實現(xiàn)過程圖解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-07-07
  • Java多線程之線程安全問題詳細解析

    Java多線程之線程安全問題詳細解析

    這篇文章主要給大家介紹了關(guān)于Java多線程之線程安全問題的相關(guān)資料,Java多線程中線程安全問題是一個常見的問題,因為多個線程可能同時訪問共享的資源,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-11-11
  • Spring--國內(nèi)Java程序員用得最多的框架

    Spring--國內(nèi)Java程序員用得最多的框架

    前幾年面試最常問的且可以順利拿到高薪的技能是Spring,隨著Spring體系的壯大,除非你在簡歷上添加Spring Boot和Spring Cloud的技能,才可以打動面試官,而現(xiàn)在,除非是Spring全家桶的實戰(zhàn)經(jīng)驗,否則難以讓面試官高看
    2021-06-06
  • Spring中的@Pointcut切點詳解

    Spring中的@Pointcut切點詳解

    這篇文章主要介紹了Spring中的@Pointcut切點詳解,pointcut就是切點,通知需要在哪些方法處進行增強,在AspectJ中用@Pointcut注解表達式標注,需要的朋友可以參考下
    2023-08-08
  • SpringBoot實現(xiàn)轉(zhuǎn)頁功能

    SpringBoot實現(xiàn)轉(zhuǎn)頁功能

    這篇文章主要介紹了SpringBoot實現(xiàn)轉(zhuǎn)頁功能,頁面的跳轉(zhuǎn)在web開發(fā)中是經(jīng)常用的基礎功能,感興趣想要詳細了解可以閱讀下文,對大家的學習或工作具有一定的參考借鑒價值
    2023-05-05

最新評論