91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

怎么在SpringBoot中使用Logback實現鏈路追蹤功能

發布時間:2021-05-27 18:09:51 來源:億速云 閱讀:224 作者:Leah 欄目:編程語言

怎么在SpringBoot中使用Logback實現鏈路追蹤功能?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

一、實現原理

Spring Boot默認使用LogBack日志系統,并且已經引入了相關的jar包,所以我們無需任何配置便可以使用LogBack打印日志。

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

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

二、代碼實戰

新建一個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("用戶創建了訂單!");
    log.info("請求完成,返回ok!");
    return "ok";
  }
  /**
   * 測試購買
   */
  @RequestMapping(value = "/testPay")
  public String testPay() {
    log.info("用戶付款!");
    return "ok";
  }
}

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

内乡县| 东至县| 定州市| 鄂尔多斯市| 白银市| 健康| 枝江市| 岳普湖县| 泌阳县| 东丽区| 沧源| 斗六市| 洛浦县| 延庆县| 宁远县| 游戏| 西充县| 新乡县| 巢湖市| 繁峙县| 随州市| 景宁| 全椒县| 仪陇县| 西安市| 吉木萨尔县| 扎赉特旗| 泽普县| 金寨县| 即墨市| 青州市| 资兴市| 万山特区| 绿春县| 西藏| 关岭| 达州市| 汝城县| 望奎县| 靖边县| 巴林左旗|