国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - Dubbo實現(xiàn)分布式日志鏈路追蹤

Dubbo實現(xiàn)分布式日志鏈路追蹤

2021-10-22 10:41weixin_39178876 Java教程

這篇文章主要介紹了Dubbo實現(xiàn)分布式日志鏈路追蹤方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

技術(shù)場景

在日常的開發(fā)、測試或運維的過程中,經(jīng)常存在這樣的場景,開發(fā)人員在代碼中使用日志工具(log4j、slf4j)記錄日志,比如請求ID、IP等,方便在線上快速、精準的定位問題,通過完整的日志鏈路清晰的進行信息定位。

一般的項目都是分層的、分布式的,在眾多的日志信息中,如何區(qū)分哪些日志信息是同一請求發(fā)出來的,詳細的實現(xiàn)如下。

技術(shù)框架

項目框架:Spring boot

分布式協(xié)調(diào):Zookeeper、Dubbo

日志工具:Sf4j

構(gòu)建工具:Maven

開發(fā)工具:IDEA

項目框架

Dubbo實現(xiàn)分布式日志鏈路追蹤

mdc-dubbo-api:接口服務(wù)

mdc-dubbo-provider:服務(wù)端服務(wù)

mdc-dubbo-consumer:消費端服務(wù)

項目配置

mdc-dubbo-api

提供一個接口

?
1
2
3
public interface OrderService {
String getOrder(String orderid);
}

mdc-dubbo-consumer

在服務(wù)端,在Controller層使用MDC工具類放入一個TRACE_LOG_ID信息,在此請求的service層、mdc-dubbo-provider中使用該信息。


Dubbo實現(xiàn)分布式日志鏈路追蹤

項目分為Controller、Service、Filter等各層:

Controller層:存放TRACE_LOG_ID, 打印

?
1
2
3
4
5
6
7
@GetMapping("get/{id}")
    public String get(@PathVariable("id") String id){
        String uuid = UUID.randomUUID().toString().replaceAll("-", "");
        MDC.put(Constants.TRACE_LOG_ID, uuid);
        LOGGER.info("controller->param:{}", id);
        return consumerService.getName(id);
    }

Service層:打印TRACE_LOG_ID

?
1
2
3
4
5
@Override
    public String getName(String id) {
        LOGGER.info("consumer->service->param:{}", id);
        return orderService.getOrder(id);
    }

Filter:

?
1
2
3
4
5
6
7
8
9
public class TraceFilter implements Filter {
@Override
    public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {
        //從MDC中獲取
        String logId = MDC.get(Constants.TRACE_LOG_ID);
        Map<String, String> attachments = invocation.getAttachments();
        attachments.put(Constants.TRACE_LOG_ID, logId);
        return invoker.invoke(invocation);
    }

需要過濾器配置在resources->MATE-INF->dobbo文件夾下

![過濾器配置https://img-blog.csdnimg.cn/20181219100406136.png)

traceFilter=com.bestpay.provider.filter.TraceFilter

此處注意 此處使用到了Dubbo中spi機制,文件名必須是com.alibaba.dubbo.rpc.Filter

dubbo配置文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://code.alibabatech.com/schema/dubbo
       http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
    <!--過濾器配置-->
   <!-- <dubbo:provider filter="traceFilter" />-->
    <!-- 應(yīng)用名-->
    <dubbo:application name="dmc-dubbo-provider"/>
    <!--zookeeper注冊中心-->
    <dubbo:registry address="zookeeper://127.0.0.1:2181"/>
 
    <dubbo:protocol name="dubbo" port="20880"/>
    <!--服務(wù)注冊-->
    <dubbo:service interface="com.bestpay.service.OrderService" ref="orderService" timeout="10000" **filter="traceFilter"**/>
    <bean id="orderService" class="com.bestpay.provider.service.OrderServiceImpl" />
 
</beans>

其中filter="traceFilter是引用dobbo目錄下配置中的key

logback配置

?
1
2
3
4
5
6
7
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
        <pattern>[%date{yyyy-MM-dd HH:mm:ss}] [%-5level] %logger %line --%mdc{client} [%X{TRACE_LOG_ID}] %msg%n</pattern>
        <!-- 控制臺也要使用UTF-8,不要使用GBK,否則會中文亂碼 -->
        <charset>UTF-8</charset>
    </encoder>
</appender>

TRACE_LOG_ID對應(yīng)放入MDC中的key

mdc-dubbo-provider

配置和## mdc-dubbo-consumer類似,其中在Filter上稍微有些差別

?
1
2
3
4
5
6
7
8
public class TraceFilter implements Filter {
    @Override
    public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {
        String logId = invocation.getAttachment(Constants.TRACE_LOG_ID);
        MDC.put(Constants.TRACE_LOG_ID, logId);
        return invoker.invoke(invocation);
    }
}

項目運行

mdc-dubbo-consumer日志:
[2018-12-19 10:16:56] [INFO ] com.bestpay.comsumer.controller.ConsumerController 33 – [d88ecba6581c47b1b3ade78d2821d13a] controller->param:223
[2018-12-19 10:16:56] [INFO ] com.bestpay.comsumer.service.impl.ComsumerServiceImpl 20 – [d88ecba6581c47b1b3ade78d2821d13a] consumer->service->param:223

mdc-dubbo-provider日志:
[2018-12-19 10:16:56] [INFO ] com.bestpay.provider.service.OrderServiceImpl 13 – [d88ecba6581c47b1b3ade78d2821d13a] provider->service->param:223

以上,完成了dubbo分布式服務(wù)之間日志的完整鏈路。為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://blog.csdn.net/weixin_39178876/article/details/85088410

延伸 · 閱讀

精彩推薦
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關(guān)于小米推送Java代碼,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩(wěn)中求8032021-07-12
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發(fā)項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程xml與Java對象的轉(zhuǎn)換詳解

    xml與Java對象的轉(zhuǎn)換詳解

    這篇文章主要介紹了xml與Java對象的轉(zhuǎn)換詳解的相關(guān)資料,需要的朋友可以參考下...

    Java教程網(wǎng)2942020-09-17
  • Java教程Java BufferWriter寫文件寫不進去或缺失數(shù)據(jù)的解決

    Java BufferWriter寫文件寫不進去或缺失數(shù)據(jù)的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數(shù)據(jù)的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發(fā)現(xiàn)了對于集合操作轉(zhuǎn)換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關(guān)于Java8中S...

    阿杜7472021-02-04
  • Java教程Java實現(xiàn)搶紅包功能

    Java實現(xiàn)搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現(xiàn)搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經(jīng)有好久沒有升過級了。升級完畢重啟之后,突然發(fā)現(xiàn)好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
主站蜘蛛池模板: 中文字幕91视频 | 欧美精品系列 | 亚洲国产精品成人 | 99在线视频播放 | av短片在线 | 精品国产乱码久久久久久牛牛 | 国产精品污www在线观看 | 久久国产精品久久久久久电车 | 自拍偷拍一区二区三区 | 亚洲精品永久视频 | 日韩色综合 | 欧美区在线 | 成人av一区二区亚洲精 | 日本a级片网站 | 欧美综合一区二区三区 | 欧美一区二区三区在线观看视频 | 欧美乱大交xxxxx春色视频 | 骚虎av| 国产精品欧美一区二区三区 | 男人的天堂久久 | 久久老妇 | 国产一级一级毛片女人精品 | 亚洲欧美精品一区二区三区 | 国产欧美精品 | 色678黄网站全部免费 | 国产欧美日韩综合精品 | 黄色片网站 | 中文在线a在线 | 老师的朋友2 | 视频一区二区三区在线观看 | 精品久久久久久久中文字幕 | 成人久久久 | 亚洲91精品 | 日韩视频一区二区三区 | 国产激情偷乱视频一区二区三区 | 91网站免费 | 中文字幕av一区二区三区免费看 | 日本一区二区精品视频 | 播放毛片 | 日本一区二区三区免费观看 | 午夜在线 |