Dubbo实现分布式日志链路追踪

作者:weixin_39178876 时间:2023-08-23 21:00:54 

技术场景

在日常的开发、测试或运维的过程中,经常存在这样的场景,开发人员在代码中使用日志工具(log4j、slf4j)记录日志,比如请求ID、IP等,方便在线上快速、精准的定位问题,通过完整的日志链路清晰的进行信息定位。

一般的项目都是分层的、分布式的,在众多的日志信息中,如何区分哪些日志信息是同一请求发出来的,详细的实现如下。

技术框架

项目框架:Spring boot

分布式协调:Zookeeper、Dubbo

日志工具:Sf4j

构建工具:Maven

开发工具:IDEA

项目框架

Dubbo实现分布式日志链路追踪

mdc-dubbo-api:接口服务

mdc-dubbo-provider:服务端服务

mdc-dubbo-consumer:消费端服务

项目配置

mdc-dubbo-api

提供一个接口


public interface OrderService {
String getOrder(String orderid);
}

mdc-dubbo-consumer

在服务端,在Controller层使用MDC工具类放入一个TRACE_LOG_ID信息,在此请求的service层、mdc-dubbo-provider中使用该信息。


Dubbo实现分布式日志链路追踪

项目分为Controller、Service、Filter等各层:

Controller层:存放TRACE_LOG_ID, 打印


@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


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

Filter:


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配置文件


<?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" />-->
   <!-- 应用名-->
   <dubbo:application name="dmc-dubbo-provider"/>
   <!--zookeeper注册中心-->
   <dubbo:registry address="zookeeper://127.0.0.1:2181"/>
<dubbo:protocol name="dubbo" port="20880"/>
   <!--服务注册-->
   <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配置


   <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对应放入MDC中的key

mdc-dubbo-provider

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


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分布式服务之间日志的完整链路。为个人经验,希望能给大家一个参考

来源:https://blog.csdn.net/weixin_39178876/article/details/85088410

标签:Dubbo,分布式,日志,链路追踪
0
投稿

猜你喜欢

  • 关于MyBaties的基本配置标签总结

    2022-08-09 17:28:44
  • 详解java中接口与抽象类的区别

    2021-09-12 03:21:39
  • System.getProperty(user.dir)定位问题解析

    2023-11-20 08:50:44
  • java高并发之线程的基本操作详解

    2023-12-04 13:35:25
  • Java设计模式之java桥接模式详解

    2023-10-15 15:19:10
  • Qt for Android开发实例教程

    2023-06-27 10:00:39
  • Java获取时间年、月、日的方法

    2022-02-10 16:58:36
  • winform去掉右上角关闭按钮的方法

    2023-02-11 16:31:40
  • Unity实现俄罗斯方块

    2021-05-28 13:37:08
  • Android编程实现图片背景渐变切换与图层叠加效果

    2021-10-10 06:04:03
  • 分享java中设置代理的两种方式

    2023-10-28 10:48:52
  • C#重写DataGridView

    2021-06-09 11:56:26
  • 新手初学Java数组

    2023-12-01 11:18:40
  • 浅谈Java由于不当的执行顺序导致的死锁

    2022-08-05 22:05:33
  • c# WPF中的TreeView使用详解

    2021-05-24 15:17:58
  • Spring Task定时任务每天零点执行一次的操作

    2021-09-12 10:59:44
  • C#抓取网络图片保存到本地的实现方法

    2023-06-28 11:35:13
  • Android开发实战之漂亮的ViewPager引导页

    2023-04-28 01:36:38
  • Android自定义边缘凹凸的卡劵效果

    2023-03-16 09:58:46
  • C#利用SharpPcap实现网络包捕获嗅探

    2021-11-24 00:47:27
  • asp之家 软件编程 m.aspxhome.com