新聞中心
[[399330]]
本文轉(zhuǎn)載自微信公眾號(hào)「Java大廠面試官」,作者laker。轉(zhuǎn)載本文請(qǐng)聯(lián)系Java大廠面試官公眾號(hào)。

成都創(chuàng)新互聯(lián)是一家專(zhuān)業(yè)提供羅湖企業(yè)網(wǎng)站建設(shè),專(zhuān)注與網(wǎng)站建設(shè)、成都網(wǎng)站建設(shè)、H5開(kāi)發(fā)、小程序制作等業(yè)務(wù)。10年已為羅湖眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專(zhuān)業(yè)網(wǎng)站設(shè)計(jì)公司優(yōu)惠進(jìn)行中。
- 前言
- 原理
- 實(shí)現(xiàn)
- 過(guò)濾器
- logback.xml
- 返回體
- 效果日志
前言
在微服務(wù)環(huán)境中,我們經(jīng)常使用Skywalking、CAT等去實(shí)現(xiàn)整體請(qǐng)求鏈路的追蹤,但是這個(gè)整體運(yùn)維成本高,架構(gòu)復(fù)雜,我們來(lái)使用MDC通過(guò)Log來(lái)實(shí)現(xiàn)一個(gè)輕量級(jí)的會(huì)話事務(wù)跟蹤功能。
原理
MDC org.sl4j.MDC其實(shí)內(nèi)部就是ThreadLocal,MDC提供了put/get/clear等幾個(gè)核心接口,用于操作ThreadLocal中的數(shù)據(jù);ThreadLocal中的K-V,可以在logback.xml中聲明,最終將會(huì)打印在日志中。
- // java代碼
- MDC.put("userId","laker");
- // logback.xml
- %X{userId}
例如:
實(shí)現(xiàn)
整體流程如下:
- 用戶登錄系統(tǒng),我們?nèi)罩局杏涗泆serId:laker。
- 用戶發(fā)起請(qǐng)求,一個(gè)請(qǐng)求中可能實(shí)際產(chǎn)生多個(gè)http請(qǐng)求,這里可以前端生成一個(gè)requestId
- 在返回體中,返回requestId。
- 研發(fā)運(yùn)維人員,可以根據(jù) userId和requestId去日志中撈請(qǐng)求鏈路。
過(guò)濾器
- @Order(value = Ordered.HIGHEST_PRECEDENCE + 100)
- @Component
- @WebFilter(filterName = "MDCFilter", urlPatterns = "/*")
- public class MDCFilter extends OncePerRequestFilter {
- @Override
- protected void doFilterInternal(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, FilterChain filterChain) throws ServletException, IOException {
- try {
- MDC.put("userId", "laker");
- MDC.put("requestId", IdUtil.fastUUID());
- } catch (Exception e) {
- //
- }
- try {
- filterChain.doFilter(httpServletRequest, httpServletResponse);
- } finally {
- MDC.clear();
- }
- }
- }
logback.xml
${LOG_HOME}/test.log true false %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{50} %line - %m%n ${LOG_HOME}/test.log.%d{yyyy-MM-dd} 15 - value="%d{HH:mm:ss.SSS} [%thread] %-5level [%X{userId}|%X{requestId}] %logger{20} - [%method,%line] - %msg%n"/>
${log.pattern} %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{50} %line - %m%n
返回體
- public class Response
{ - @ApiModelProperty(notes = "響應(yīng)碼,非200 即為異常", example = "200")
- private final int code;
- @ApiModelProperty(notes = "響應(yīng)消息", example = "提交成功")
- private final String msg;
- @ApiModelProperty(notes = "響應(yīng)數(shù)據(jù)")
- private final T data;
- @ApiModelProperty(notes = "請(qǐng)求id")
- private final String requestId;
- public Response(int code, String msg, T data) {
- this.code = code;
- this.msg = msg;
- this.data = data;
- this.requestId = MDC.get("requestId");
- }
效果日志
響應(yīng)
- {
- code: 200,
- msg: "",
- requestId: "74a269a8-3cb4-417e-853c-b968b77cce23"
- }
日志
- 18:37:15.997 [http-nio-8080-exec-1] INFO [laker|90717490-5ef4-4e46-bc2c-605952fc3803] c.l.m.c.InfoController - [v2Map,17] - null
- 18:37:38.980 [http-nio-8080-exec-2] INFO [laker|82bde351-f86e-466f-97a0-c857a0c4c1c9] c.l.m.c.InfoController - [v2Map,17] - null
- 18:37:39.992 [http-nio-8080-exec-3] INFO [laker|74a269a8-3cb4-417e-853c-b968b77cce23] c.l.m.c.InfoController - [v2Map,17] - null
網(wǎng)頁(yè)名稱(chēng):從零搭建開(kāi)發(fā)腳手架 使用MDC實(shí)現(xiàn)日志鏈路跟蹤
瀏覽地址:http://www.dlmjj.cn/article/cdoiphj.html


咨詢(xún)
建站咨詢(xún)
