中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

Dubbo日志鏈路追蹤TraceId怎么選型

發布時間:2021-12-23 17:31:20 來源:億速云 閱讀:214 作者:iii 欄目:大數據

本篇內容介紹了“Dubbo日志鏈路追蹤TraceId怎么選型”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

一、目的

開發排查系統問題用得最多的手段就是查看系統日志,但是在分布式環境下使用日志定位問題還是比較麻煩,需要借助 全鏈路追蹤ID 把上下文串聯起來,本文主要分享基于 Spring Boot + Dubbo 框架下 日志鏈路追蹤ID 的實現方案選型思路。

Dubbo日志鏈路追蹤TraceId怎么選型

全鏈路追蹤的核心思想:

  • 為每條請求都單獨分配一個唯一的 traceId 用來標識一條請求鏈路,該 traceId 會貫穿整個請求處理過程的所有服務

  • 每個服務/線程都擁有自己的 spanId 標識,代表請求的其中一段處理步驟

  • 一個請求包含一個 traceId 和一個或多個 spanId

日志全鏈路追蹤 就是在每條系統日志里都添加顯示 traceIdspanId 信息

Dubbo日志鏈路追蹤TraceId怎么選型

二、方案選型

2.1. 方案一(apm-toolkit)

這是 SkyWalking 的一個日志插件,通過這個插件可以在日志中輸出 traceId

2.1.1. 使用方式

配置依賴,在 pom 文件中添加以下內容

<dependency>
    <groupId>org.apache.skywalking</groupId>
    <artifactId>apm-toolkit-logback-1.x</artifactId>
    <version>8.1.0</version>
</dependency>

配置日志模板,修改 logback-spring.xml 文件中 Appender 元素的 encoder 為以下內容

<encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
    <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">
        <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%tid] [%thread] %-5level %logger{35} - %msg%n</pattern>
    </layout>
</encoder>

ps: pattern 中的內容按需修改,其中的 %tid 就是相當于 traceId,默認 TID:N/A,當有請求調用時會生成并顯示 traceId

2.1.2. 總結
  • 優點:無需編碼,業務無入侵,可與 SkyWalking 的圖形化界面中使用該ID快速定位各種接口的調用關系。

  • 缺點:強耦合 SkyWalking 才能生效

    • 必須添加sk的 javaagent

    • 必須部署 SkyWalking 服務端

2.2. 方案二(sleuth)

SleuthSpring Cloud 的組件之一,它為 Spring Cloud 實現了一種分布式追蹤解決方案,兼容Zipkin,HTrace與其他日志追蹤系統

2.2.1. 使用方式

配置父依賴,在 pom 文件中添加以下內容管理版本號

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-sleuth</artifactId>
            <version>2.2.4.RELEASE</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
</dependencyManagement>

配置依賴,在 pom 文件中添加以下內容

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-sleuth</artifactId>
</dependency>

適配dubbo,要讓 sleuth 支持 dubbo 框架,需要增加以下兩個步驟:

首先添加 dubbo 的插件依賴

<dependency>
    <groupId>io.zipkin.brave</groupId>
    <artifactId>brave-instrumentation-dubbo-rpc</artifactId>
    <version>5.12.6</version>
</dependency>

配置 dubbo 過濾器

dubbo:
  provider:
    filter: tracing
  consumer:
    filter: tracing

配置日志模板,修改 logback-spring.xml 文件中 Appender 元素的 encoder 為以下內容

<encoder>
    <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%X{X-B3-TraceId},%X{X-B3-SpanId}] [%thread] %-5level %logger{35} - %msg%n</pattern>
    <charset>utf-8</charset>
</encoder>

ps: pattern 中的內容按需修改,其中的 %X{X-B3-TraceId} 為 traceId,%X{X-B3-SpanId} 為 spanId

2.2.2. 總結
  • 優點:業務無入侵,有豐富的插件進行擴展包括定時任務、MQ等。

  • 缺點brave-instrumentation-dubbo-rpc 不支持 dubbo 2.7.x 需要自行開發插件。

2.3. 方案三(自研)

2.3.1. 無入侵增加 traceId

使用 LogbackMDC 機制,在日志模板中加入 traceId 標識,取值方式為 %X{traceId}

  1. 系統入口(api網關)創建 traceId 的值

  2. 使用 MDC 保存 traceId

  3. 修改 logback 配置文件模板格式添加標識 %X{traceId}

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

2.3.2. 跨線程傳遞

解決 traceId 跨線程丟失問題

Dubbo日志鏈路追蹤TraceId怎么選型

由于 MDC 內部使用的是 ThreadLocal 所以只有本線程才有效,子線程和下游的服務 MDC 里的值會丟失;

需要解決 Spring 的各種線程池與異步方法的父子線程間傳遞。

解決思路:重寫一個 MDCAdapter 使用阿里的 TransmittableThreadLocal 替換原來的 ThreadLocal 對象,解決各種線程池(ExecutorService / ForkJoinPool / TimerTask)父子進程傳值問題。

需要使用 TtlRunnableTtlCallable 來修飾傳入線程池的 RunnableCallable

2.3.3. 跨進程傳遞

解決 traceId 跨進程丟失問題

dubbo服務 使用 org.apache.dubbo.rpc.Filter 創建一個過濾器進行 traceId 傳遞

  • 服務消費者:負責傳遞鏈路追蹤 ID

  • 服務提供者:負責接收 ID 并保存到 MDC

2.3.4. 總結
  • 優點:業務無入侵,最小依賴,擴展靈活,適配性強。

  • 缺點:需要自行實現,有大量的開發工作量。

三、方案總結

方案開發工作量可維護性入侵性性能
apm-toolkit業務無入侵
sleuth業務無入侵
自研業務無入侵

“Dubbo日志鏈路追蹤TraceId怎么選型”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

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

AI

十堰市| 通海县| 合水县| 房产| 乌兰浩特市| 获嘉县| 嵊泗县| 长兴县| 宜宾县| 新郑市| 雅安市| 旅游| 辉县市| 勐海县| 江城| 育儿| 乐东| 正蓝旗| 彭泽县| 绍兴市| 将乐县| 平顶山市| 鲁山县| 成武县| 固镇县| 溧阳市| 交口县| 文安县| 台湾省| 思南县| 沂源县| 吴江市| 灵山县| 金坛市| 兰州市| 延庆县| 德阳市| 晋中市| 舒城县| 邻水| 阿合奇县|