Dubbo Logback 远程调用携带traceid

背景

A项目有调用B项目的服务,A项目使用 logback 且有 MDC 方式做 traceid,调用B项目的时候,traceid 没传递过期,导致有时候不好排查问题和链路追踪

准备工作

因为使用的是 alibaba 的 dubbo 所以需要加入单独的包

ml 复制代码
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>transmittable-thread-local</artifactId>
    <version>2.14.5</version>
</dependency>

Dubbo拦截器代码

java 复制代码
import com.alibaba.dubbo.common.extension.Activate;
import com.alibaba.dubbo.rpc.*;
import com.dflm.weixin.util.LogUtils;
import lombok.extern.slf4j.Slf4j;
import org.slf4j.MDC;

@Slf4j
@Activate(group = {"consumer", "provider"})
public class DubboLogTraceFilter implements Filter {

    @Override
    public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {
        String logUUid = null;
        if (RpcContext.getContext().isConsumerSide()) {
            // 消费者 作为消费者,上下文中有 trace id
            logUUid = MDC.get(LogUtils.LOG_TRACE_ID);
            RpcContext.getContext().setAttachment(LogUtils.LOG_TRACE_ID, logUUid);
            log.info("DubboLogTraceFilter 消费者 设置 trace id {}", logUUid);
        } else {
            // 生产者 取出 trace id
            logUUid = RpcContext.getContext().getAttachment(LogUtils.LOG_TRACE_ID);
            log.info("DubboLogTraceFilter 生产者 取出 trace id {}", logUUid);
            MDC.put(LogUtils.LOG_TRACE_ID, logUUid);
        }
        try {
            return invoker.invoke(invocation);
        } finally {
            if (RpcContext.getContext().isProviderSide()) {
                MDC.remove(LogUtils.LOG_TRACE_ID);
                log.info("DubboLogTraceFilter 移除 trace id {}", logUUid);
            }
        }
    }
}

配置文件

resources 目录下面的META-INF 文件夹中新建dubbo 文件夹,新建文件com.alibaba.dubbo.rpc.Filter

注意的是代码中继承的Filter是哪个包就写哪个包,不然写成apach的是不会生效的,文件内容就是配置的Filter的类路径和名称

java 复制代码
com.wemew.filter.DubboLogTraceFilter

效果

A 服务

B 服务

相关推荐
武子康1 天前
Java-80 深入浅出 RPC Dubbo 动态服务降级:从雪崩防护到配置中心秒级生效
java·分布式·后端·spring·微服务·rpc·dubbo
百度SEO专员2 天前
2025最新蜘蛛池在百度SEO中的应用
dubbo
程序员的世界你不懂3 天前
Jmeter常见问题分析(1)乱码问题
jmeter·dubbo
武子康6 天前
Java-78 深入浅出 RPC Dubbo 负载均衡全解析:策略、配置与自定义实现实战
java·数据库·分布式·后端·缓存·rpc·dubbo
躲在没风的地方9 天前
logback日志控制服务器日志输出
java·服务器·logback
武子康9 天前
Java-77 深入浅出 RPC Dubbo 负载均衡全解析:策略、配置与自定义实现实战
java·分布式·后端·spring·微服务·rpc·dubbo
武子康11 天前
Java-75 深入浅出 RPC Dubbo Java SPI机制详解:从JDK到Dubbo的插件式扩展
java·分布式·后端·spring·微服务·rpc·dubbo
Easonmax11 天前
文心一言4.5深度评测:国产大模型的崛起之路
dubbo
武子康12 天前
Java-74 深入浅出 RPC Dubbo Admin可视化管理 安装使用 源码编译、Docker启动
java·分布式·后端·spring·docker·rpc·dubbo
武子康13 天前
Java-71 深入浅出 RPC Dubbo 上手 父工程配置编写 附详细POM与代码
java·分布式·程序人生·spring·微服务·rpc·dubbo