精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

從零搭建開發腳手架 使用MDC實現日志鏈路跟蹤

開發 架構
在微服務環境中,我們經常使用Skywalking、CAT等去實現整體請求鏈路的追蹤,但是這個整體運維成本高,架構復雜,我們來使用MDC通過Log來實現一個輕量級的會話事務跟蹤功能。
本文轉載自微信公眾號「Java大廠面試官」,作者laker。轉載本文請聯系Java大廠面試官公眾號。
  • 前言
  • 原理
  • 實現
    • 過濾器
    • logback.xml
    • 返回體
  • 效果日志

前言

在微服務環境中,我們經常使用Skywalking、CAT等去實現整體請求鏈路的追蹤,但是這個整體運維成本高,架構復雜,我們來使用MDC通過Log來實現一個輕量級的會話事務跟蹤功能。

原理

MDC org.sl4j.MDC其實內部就是ThreadLocal,MDC提供了put/get/clear等幾個核心接口,用于操作ThreadLocal中的數據;ThreadLocal中的K-V,可以在logback.xml中聲明,最終將會打印在日志中。

  1. // java代碼 
  2. MDC.put("userId","laker");   
  3.  
  4. // logback.xml 
  5. %X{userId} 

例如:

  1. <property name="pattern" value="%d{HH:mm:ss.SSS} [%thread] %-5level [%X{userId}] %logger{20} - %msg%n"/> 

實現

整體流程如下:

  • 用戶登錄系統,我們日志中記錄userId:laker。
  • 用戶發起請求,一個請求中可能實際產生多個http請求,這里可以前端生成一個requestId
  • 在返回體中,返回requestId。
  • 研發運維人員,可以根據 userId和requestId去日志中撈請求鏈路。

過濾器

  1. @Order(value = Ordered.HIGHEST_PRECEDENCE + 100) 
  2. @Component 
  3. @WebFilter(filterName = "MDCFilter", urlPatterns = "/*"
  4. public class MDCFilter extends OncePerRequestFilter { 
  5.  
  6.     @Override 
  7.     protected void doFilterInternal(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, FilterChain filterChain) throws ServletException, IOException { 
  8.         try { 
  9.             MDC.put("userId""laker"); 
  10.             MDC.put("requestId", IdUtil.fastUUID()); 
  11.         } catch (Exception e) { 
  12.             // 
  13.         } 
  14.  
  15.         try { 
  16.             filterChain.doFilter(httpServletRequest, httpServletResponse); 
  17.         } finally { 
  18.             MDC.clear(); 
  19.         } 
  20.     } 

logback.xml

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <configuration> 
  3.     <property name="LOG_HOME" value="logs"/> 
  4.     <property name="encoding" value="UTF-8"/> 
  5.  
  6.     <appender name="DEFAULT" class="ch.qos.logback.core.rolling.RollingFileAppender"
  7.         <file>${LOG_HOME}/test.log</file> 
  8.         <Append>true</Append> 
  9.         <prudent>false</prudent> 
  10.         <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"
  11.             <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{50} %line - %m%n</pattern> 
  12.         </encoder> 
  13.         <!-- 按天回滾 daily --> 
  14.         <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"
  15.             <!--歸檔日志文件名--> 
  16.             <FileNamePattern>${LOG_HOME}/test.log.%d{yyyy-MM-dd}</FileNamePattern> 
  17.             <!-- 最多保存15天歷史文件 --> 
  18.             <maxHistory>15</maxHistory> 
  19.         </rollingPolicy> 
  20.     </appender> 
  21.  
  22.     <!-- 日志輸出格式 --> 
  23.     <property name="log.pattern" 
  24.               value="%d{HH:mm:ss.SSS} [%thread] %-5level [%X{userId}|%X{requestId}] %logger{20} - [%method,%line] - %msg%n"/> 
  25.  
  26.     <!-- 控制臺輸出 --> 
  27.     <appender name="console" class="ch.qos.logback.core.ConsoleAppender"
  28.         <encoder> 
  29.             <pattern>${log.pattern}</pattern> 
  30.         </encoder> 
  31.     </appender> 
  32.  
  33.     <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"
  34.         <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"
  35.             <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{50} %line - %m%n</pattern> 
  36.         </encoder> 
  37.     </appender> 
  38.  
  39.     <logger name="com.test.demo" level="DEBUG"
  40.         <appender-ref ref="DEFAULT"/> 
  41.     </logger> 
  42.     <!-- 日志輸出級別 --> 
  43.     <root level="INFO"
  44.         <appender-ref ref="DEFAULT"/> 
  45.         <appender-ref ref="console"/> 
  46.     </root> 
  47. </configuration> 

返回體

  1. public class Response<T> { 
  2.     @ApiModelProperty(notes = "響應碼,非200 即為異常", example = "200"
  3.     private final int code; 
  4.     @ApiModelProperty(notes = "響應消息", example = "提交成功"
  5.     private final String msg; 
  6.     @ApiModelProperty(notes = "響應數據"
  7.     private final T data; 
  8.     @ApiModelProperty(notes = "請求id"
  9.     private final String requestId; 
  10.  
  11.     public Response(int code, String msg, T data) { 
  12.         this.code = code; 
  13.         this.msg = msg; 
  14.         this.data = data; 
  15.         this.requestId = MDC.get("requestId"); 
  16.     } 

效果日志

響應

  1.  code: 200, 
  2.  msg: ""
  3.  requestId: "74a269a8-3cb4-417e-853c-b968b77cce23" 

日志

  1. 18:37:15.997 [http-nio-8080-exec-1] INFO  [laker|90717490-5ef4-4e46-bc2c-605952fc3803] c.l.m.c.InfoController - [v2Map,17] - null 
  2. 18:37:38.980 [http-nio-8080-exec-2] INFO  [laker|82bde351-f86e-466f-97a0-c857a0c4c1c9] c.l.m.c.InfoController - [v2Map,17] - null 
  3. 18:37:39.992 [http-nio-8080-exec-3] INFO  [laker|74a269a8-3cb4-417e-853c-b968b77cce23] c.l.m.c.InfoController - [v2Map,17] - null 

 

責任編輯:武曉燕 來源: Java大廠面試官
相關推薦

2021-04-28 16:10:48

開發腳手架 Spring

2021-04-20 19:24:16

腳手架 Java微信

2021-09-01 10:07:43

開發零搭建Groovy

2021-04-13 14:47:53

認證授權Java

2021-07-13 18:42:38

Spring Boot腳手架開發

2020-08-19 08:55:47

Redis緩存數據庫

2021-03-09 17:11:09

數據庫腳手架開發

2021-06-02 17:58:49

腳手架 冪等性前端

2021-02-19 22:43:50

開發腳手架Controller

2021-07-29 18:49:49

Spring開發腳手架

2021-03-11 14:16:47

Spring Boo開發腳手架

2016-08-10 14:59:41

前端Javascript工具

2018-08-30 16:08:37

Node.js腳手架工具

2018-06-11 14:39:57

前端腳手架工具node.js

2023-11-21 17:36:04

OpenFeignSentinel

2014-08-15 09:36:06

2021-01-07 05:34:07

腳手架JDK緩存

2025-05-26 08:50:00

SLF4JMDC全鏈路追蹤

2021-05-21 05:22:52

腳手架工具項目

2025-01-20 08:10:00

微服務架構SLF4J
點贊
收藏

51CTO技術棧公眾號

日韩中文字幕综合| 国产一级在线视频| 日韩欧美专区| 亚洲国产成人va在线观看天堂| 久久99精品国产99久久| 波多野结衣在线观看视频| 99视频精品全国免费| 日韩三级视频在线看| 精品国产成人av在线免| 国产激情小视频在线| 91在线精品一区二区| 国产在线播放不卡| 亚洲精品77777| 欧美3p视频| 日韩理论片久久| 91亚洲一区二区| 激情开心成人网| 亚洲一区二区三区国产| 性欧美精品一区二区三区在线播放| a天堂在线视频| 日韩在线卡一卡二| 韩国一区二区电影| 国产成人免费在线观看视频| 欧美调教网站| 欧美一区二区视频在线观看2022| 日韩欧美在线播放视频| 91蜜桃在线视频| 欧美国产一区在线| 久久久www免费人成黑人精品| 99久久精品国产一区色| 日韩中文字幕区一区有砖一区| 国内精品久久久久| 极品盗摄国产盗摄合集| 日韩一区自拍| 亚洲日本欧美日韩高观看| 成人做爰69片免费| 精品一区二区三区在线观看视频| 色婷婷av一区二区| 97超碰青青草| 黄色软件视频在线观看| 亚洲制服欧美中文字幕中文字幕| 中文字幕成人一区| 日韩免费啪啪| 中文字幕av资源一区| 青青草成人网| 久草视频视频在线播放| 91麻豆成人久久精品二区三区| 99久久99久久精品国产片| 国产精品久久久久久久免费看| 免费成人av在线| 国产精品免费一区| 中文字幕乱码视频| 奇米色一区二区| 国产精品久久一区| 国产一级精品毛片| 蜜桃视频第一区免费观看| 国产精品美女久久久久久免费| 夜夜爽妓女8888视频免费观看| 久久都是精品| 国产精品久久久久久久久久久久久 | 大j8黑人w巨大888a片| 2019中文字幕在线电影免费| 婷婷中文字幕一区三区| 色综合久久久久无码专区| 麻豆国产在线| 色综合久久66| wwwwxxxx日韩| 久久三级毛片| 日韩一级片在线播放| 国产av一区二区三区传媒| 国产精品毛片视频| 日韩精品小视频| 日本爱爱爱视频| 911精品美国片911久久久 | 日本欧美色综合网站免费| 精品视频二区| 国产精品白丝在线| 精品无码av无码免费专区| 欧美人与动牲性行为| 亚洲国产精品一区二区久久恐怖片 | 香蕉视频久久久| 99国产**精品****| 欧美另类高清videos| 亚洲欧美在线视频免费| 爽爽淫人综合网网站| 国产一区红桃视频| 性欧美18一19性猛交| 91丨九色丨黑人外教| 日韩一区二区三区高清| 182tv在线播放| 欧美日韩国产在线| 国产精品一区二区羞羞答答| 麻豆久久一区| 亚洲美女性视频| 国产一二三四视频| 亚洲欧洲另类| 国产精品久久久久久久久久久久久| 国产视频一区二区三| caoporn国产一区二区| 亚洲视频电影| a国产在线视频| 欧美日韩激情一区二区| 人妻 丝袜美腿 中文字幕| 国产成人三级| 久久久久久国产三级电影| 亚洲图片欧美日韩| 国产91精品在线观看| 午夜精品一区二区三区在线观看| 美女精品视频| 欧美日韩一区二区欧美激情| 国产一级伦理片| 婷婷久久国产对白刺激五月99| 午夜精品福利视频| 国产绳艺sm调教室论坛| 国产日产精品1区| 国产日韩av网站| 香蕉久久一区| 永久免费毛片在线播放不卡| 久久综合亚洲色hezyo国产| 蜜桃久久av一区| 欧美连裤袜在线视频| 欧美人与性动交α欧美精品济南到| 欧美少妇bbb| 人妻熟女aⅴ一区二区三区汇编| 这里只有精品在线| 国产精品一区二区女厕厕| 亚洲色图另类小说| 亚洲一本大道在线| 中文字幕第66页| 日韩精品91| 国产精品久久久久久av福利| 久久精品蜜桃| 午夜久久电影网| 精人妻一区二区三区| 久久久久国产精品| 国产精品国产自产拍高清av水多| 日本一区二区三区在线观看视频| 一区二区三区国产精品| 99中文字幕在线| 午夜国产一区二区| 国产精品美女久久久免费| 成人资源www网在线最新版| 欧美性高潮在线| 最新的欧美黄色| 国产精品播放| 川上优的av在线一区二区| 黑人巨大精品欧美一区二区三区 | 欧产日产国产69| av亚洲精华国产精华精| 91免费黄视频| 岛国av一区| 久久久久久久亚洲精品| 亚洲精品一级片| 亚洲综合激情网| 99久久久无码国产精品性波多| 国产综合视频| 国产厕所精品在线观看| 久草在线新免费首页资源站| 亚洲精品在线网站| 国产对白videos麻豆高潮| 99久久精品免费| 黄色免费视频大全| 久久综合色占| 国产狼人综合免费视频| 美女羞羞视频在线观看| 欧美一二三四区在线| 久久97人妻无码一区二区三区| 国产福利一区二区| 国产一区二区三区小说| 亚洲小说图片视频| 国产精品爽爽爽爽爽爽在线观看| 秋霞午夜理伦电影在线观看| 欧美成人官网二区| 日本网站免费观看| 久久久精品人体av艺术| 日本中文字幕二区| 国内在线观看一区二区三区| 国产伦精品一区二区三区| 竹内纱里奈兽皇系列在线观看| 国产一区二区三区18| 国产精品一区二区免费视频| 亚洲午夜私人影院| 国产ts在线播放| 国产成人自拍高清视频在线免费播放| 男人添女荫道口女人有什么感觉| 国产成人黄色| 91pron在线| 成年美女黄网站色大片不卡| 色悠悠久久久久| 日本毛片在线观看| 欧美在线观看你懂的| 九九九久久久久| 国产喷白浆一区二区三区| 国产精品久久久久久久99| 99视频精品| 四虎影院一区二区| 外国成人在线视频| 成人午夜激情网| 蜜桃视频在线观看免费视频| 久久精品国产视频| 你懂的在线视频| 日韩视频在线你懂得| 免费在线观看av的网站| 亚洲成人精品影院| 少妇视频一区二区| 久久免费精品国产久精品久久久久| 日本精品一区在线| 日韩精品成人一区二区三区| 美女黄色免费看| 希岛爱理一区二区三区| 久久久久一区二区| 69精品国产久热在线观看| 国产欧美精品va在线观看| 成人线上视频| 欧美国产日韩二区| 欧洲不卡视频| 永久免费精品影视网站| 天天摸夜夜添狠狠添婷婷| 91精品国产乱| 一级片一区二区三区| 一本久道中文字幕精品亚洲嫩| 久久久久亚洲av无码专区| 国产精品久久久久桃色tv| 波多野结衣片子| 91在线视频播放地址| 俄罗斯黄色录像| 国产美女一区二区三区| 久久人人爽av| 青青草国产成人99久久| 免费裸体美女网站| 制服诱惑一区二区| 亚洲人精品午夜射精日韩 | 欧美床上激情在线观看| 欧美极品视频| 最近2019中文字幕大全第二页| 国产三级在线免费| 亚洲人成电影在线播放| 日韩福利一区二区| 精品视频中文字幕| 无码国精品一区二区免费蜜桃| 亚洲国产成人精品久久| 人妻91麻豆一区二区三区| 精品美女在线播放| 男人天堂av网| 亚洲国产日韩欧美在线动漫| 黄色av小说在线观看| 精品美女在线观看| 日本精品999| 精品亚洲aⅴ在线观看| 深夜影院在线观看| 亚洲人成网站在线播| 韩国免费在线视频| 中文字幕亚洲综合久久筱田步美 | 欧美黑人一级爽快片淫片高清| 成人在线影视| 欧美黑人xxx| 超碰在线公开| 日本一区二区在线免费播放| 欧美与亚洲与日本直播| 国产精品入口尤物| 国产精品一区二区三区www| 亚洲最大成人在线| 国产在线播放精品| 久热国产精品视频一区二区三区| 免费精品国产| 亚洲欧洲精品在线 | 97caocao| 欧美大片日本大片免费观看| 熟妇人妻一区二区三区四区 | 成年视频在线观看| 色综合色综合久久综合频道88| www欧美xxxx| 欧洲亚洲在线视频| 欧美美女福利视频| 99九九电视剧免费观看| 亚洲人亚洲人色久| 中文字幕在线观看一区二区三区| 国产尤物精品| 久久久久久久片| 国产一区激情在线| 日韩aaaaa| 中文字幕永久在线不卡| 国产精品111| 欧美亚洲自拍偷拍| 亚洲爱情岛论坛永久| 亚洲精品自拍偷拍| 国产黄a三级三级三级av在线看| 久久免费高清视频| 国产美女久久| 精品国产乱码久久久久久88av | 欧美日韩视频免费| 日韩黄色免费网站| 午夜不卡久久精品无码免费| 欧美韩国日本一区| 国产精品一区二区6| 4438x成人网最大色成网站| 视频在线不卡| 欧美韩国理论所午夜片917电影| 视频在线日韩| 国产乱码精品一区二区三区日韩精品 | 日韩专区视频| 欧美精品一区二区三区久久| 亚洲一区二区日韩| av在线无限看| 成年人国产精品| 欧美极品视频在线观看| 欧日韩精品视频| 五月婷婷久久久| 欧美情侣性视频| 亚洲一区有码| 日韩精品在在线一区二区中文| 尤物精品在线| 亚洲国产日韩在线一区| 亚洲国产激情av| 国产精品国产三级国产专区52| 日韩一区二区影院| 欧美69xxx| 国产精品久久久久久超碰| 久久99国产精品久久99大师 | 欧美一区二区三区啪啪| 成年人视频在线免费观看| 欧美在线日韩在线| 成人免费直播在线| 丰满人妻一区二区三区53号| 久久电影网电视剧免费观看| 亚洲区自拍偷拍| 一本大道久久a久久精品综合| 黑人精品一区二区三区| 久久国产精品电影| 96sao精品免费视频观看| 亚洲va久久久噜噜噜久久狠狠| 亚洲欧美大片| 国产精品伦子伦| 午夜精品福利一区二区三区av | 在线日韩第一页| 欧美极度另类| 欧美第一黄网| 天堂在线亚洲视频| 国产女主播喷水高潮网红在线| 欧美日韩久久久久| 性感美女一级片| 97视频在线观看视频免费视频| 高清日韩中文字幕| 久久亚洲中文字幕无码| 不卡高清视频专区| 亚州国产精品视频| 国产视频久久网| 欧洲亚洲两性| 亚洲乱码一区二区三区 | 欧美日韩国产在线播放| 日本精品久久久久| 7777免费精品视频| 美女网站一区| 婷婷丁香激情网| 自拍偷拍国产精品| 精品人妻一区二区三区日产乱码| 色综合视频网站| 色天天色综合| 欧美精品成人网| 中文字幕亚洲在| www.五月婷| 欧美亚洲第一页| 精品国产精品国产偷麻豆| 亚洲欧美偷拍另类| 一区二区三区四区蜜桃| 韩国av免费在线观看| 国产91精品久久久久久| 欧美一站二站| 久久久久亚洲av无码麻豆| 亚洲大片精品永久免费| 噜噜噜在线观看播放视频| 国产在线精品一区免费香蕉| 国产精品mm| 国产全是老熟女太爽了| 精品视频在线免费观看| 污片视频在线免费观看| 蜜桃视频在线观看成人| 激情深爱一区二区| 男人的天堂一区二区| 亚洲性夜色噜噜噜7777| 国产精品久久久久久久久久久久久久久 | 日韩视频在线你懂得| av资源中文在线天堂| 午夜一区二区三区| 成人丝袜视频网| 亚洲精品国产精品国自产网站按摩| 久久视频在线观看免费| 奇米影视777在线欧美电影观看| 日本xxxx黄色| 亚洲午夜成aⅴ人片| 国产福利免费在线观看| 电影午夜精品一区二区三区| 日韩中文字幕亚洲一区二区va在线| 欧美精品久久久久久久久46p| 日韩二区三区在线| 疯狂欧洲av久久成人av电影| 男人操女人逼免费视频| 亚洲精品福利视频网站| 狠狠v欧美ⅴ日韩v亚洲v大胸| 91亚洲精品在线观看|