返回顶部
首页 > 资讯 > 精选 >Java gRPC拦截器如何实现分布式日志链路追踪器
  • 114
分享到

Java gRPC拦截器如何实现分布式日志链路追踪器

2023-07-05 07:07:16 114人浏览 泡泡鱼
摘要

这篇文章主要介绍“Java grpc拦截器如何实现分布式日志链路追踪器”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java grpc拦截器如何实现分布式日志链路追踪器”文章能帮

这篇文章主要介绍“Java grpc拦截器如何实现分布式日志链路追踪器”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java grpc拦截器如何实现分布式日志链路追踪器”文章能帮助大家解决问题。

跨进程链路追踪原理

想要实现跨进程间的分布式链路追踪,就要在发起远程调用的时候通过请求头或者公共的自定义域将链路参数放进去,然后服务端收到请求后将链路参数从请求头或者自定义域中或取出来,就这样一层一层的将链路参数传递下去直至调用结束。

JAVA的gRPC库io.grpc提供了在RPC调用中客户端和服务端的拦截器(Interceptor),通过客户端拦截器我们可以将链路追踪的参数放到gRPC调用的Metadata中,通过服务端拦截器能够从Metadata中获取到链路追踪所传递的参数;io.grpc提供的客户端拦截器和服务端拦截器分别是io.grpc.ClientInterceptorio.grpc.ServerInterceptor

代码实现

Maven依赖

    <dependencies>        <dependency>            <groupId>io.grpc</groupId>            <artifactId>grpc-all</artifactId>            <version>${grpc.version}</version>            <scope>provided</scope>        </dependency>        <dependency>            <groupId>net.devh</groupId>            <artifactId>grpc-server-spring-boot-starter</artifactId>            <version>${grpc.starter.version}</version>            <scope>provided</scope>        </dependency>        <dependency>            <groupId>net.devh</groupId>            <artifactId>grpc-client-spring-boot-starter</artifactId>            <version>${grpc.starter.version}</version>            <scope>provided</scope>        </dependency>        <dependency>            <groupId>io.GitHub.redick01</groupId>            <artifactId>log-helper-spring-boot-starter-common</artifactId>            <version>1.0.3-RELEASE</version>        </dependency>    </dependencies>

拦截器实现

@Slf4j@GrpcGlobalClientInterceptor@GrpcGlobalServerInterceptorpublic class GrpcInterceptor extends AbstractInterceptor implements ServerInterceptor, ClientInterceptor {    // 链路追踪参数traceId    private static final Metadata.Key<String> TRACE = Metadata.Key.of("traceId", Metadata.ASCII_STRING_MARSHALLER)    // 链路追踪参数spanId    private static final Metadata.Key<String> SPAN = Metadata.Key.of("spanId", Metadata.ASCII_STRING_MARSHALLER);    // 链路追踪参数parentId    private static final Metadata.Key<String> PARENT = Metadata.Key.of("parentId", Metadata.ASCII_STRING_MARSHALLER);    @Override    public <ReQt, RespT> ClientCall<ReqT, RespT> interceptCall(            MethodDescriptor<ReqT, RespT> methodDescriptor, CallOptions callOptions,            Channel channel) {        StopWatch stopWatch = new StopWatch();        stopWatch.start();        try {            return new ForwardinGClientCall.SimpleForwardingClientCall<ReqT, RespT>(channel.newCall(methodDescriptor, callOptions)) {                @Override                public void start(Listener<RespT> responseListener, Metadata headers) {                    // 客户端传递链路追中数据,将数据放到headers中                    String traceId = traceId();                    if (StringUtils.isNotBlank(traceId)) {                        headers.put(TRACE, traceId);                        headers.put(SPAN, spanId());                        headers.put(PARENT, parentId());                    }                    // 继续下一步                    super.start(new ForwardingClientCallListener.SimpleForwardingClientCallListener<RespT>(responseListener) {                        @Override                        public void onHeaders(Metadata headers) {                            // 服务端传递回来的header                            super.onHeaders(headers);                        }                    }, headers);                }            };        } finally {            stopWatch.stop();            log.info(LogUtil.marker(stopWatch.getTime()), "GRPC调用耗时");        }    }    @Override    public <ReqT, RespT> Listener<ReqT> interceptCall(ServerCall<ReqT, RespT> serverCall,            Metadata headers, ServerCallHandler<ReqT, RespT> serverCallHandler) {        // 服务端从headers中获取到链路追踪参数        String traceId = headers.get(TRACE);        String spanId = headers.get(SPAN);        String parentId = headers.get(PARENT);        // 构建当前进程的链路追踪数据并体现在日志中        Tracer.trace(traceId, spanId, parentId);        log.info(LogUtil.marker(), "开始处理");        return serverCallHandler.startCall(new ForwardingServerCall.SimpleForwardingServerCall<ReqT, RespT>(serverCall) {            @Override            public void sendHeaders(Metadata responseHeaders) {                super.sendHeaders(responseHeaders);            }            @Override            public void close(Status status, Metadata trailers) {                super.close(status, trailers);            }        }, headers);    }}

客户端使用

客户端使用代码如下,该使用示例是在我开源的日志工具中的例子,我这里通过SpringBoot自动装配将GrpcInterceptor交由spring容器管理。所以可以直接通过自动注入的方式使用。

@RestControllerpublic class TestController {    @GrpcClient("userClient")    private UserServiceGrpc.UserServiceBlockingStub userService;    @Autowired    private GrpcInterceptor grpcInterceptor;    //@LogMarker(businessDescription = "获取用户名")    @GetMapping("/getUser")    public String getUser()     {        User user = User.newBuilder()                .setUserId(100)                .putHobbys("pingpong", "play pingpong")                .setCode(200)                .build();        Channel channel = ClientInterceptors.intercept(userService.getChannel(), grpcInterceptor);        userService = UserServiceGrpc.newBlockingStub(channel);        User u = userService.getUser(user);        return u.getName();    }}

关于“Java gRPC拦截器如何实现分布式日志链路追踪器”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: Java gRPC拦截器如何实现分布式日志链路追踪器

本文链接: https://lsjlt.com/news/350388.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Java gRPC拦截器如何实现分布式日志链路追踪器
    这篇文章主要介绍“Java gRPC拦截器如何实现分布式日志链路追踪器”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java gRPC拦截器如何实现分布式日志链路追踪器”文章能帮...
    99+
    2023-07-05
  • JavagRPC拦截器简单实现分布式日志链路追踪器过程详解
    目录跨进程链路追踪原理代码实现总结之前开源过一个分布式日志链路追踪的工具,其作用是规范日志格式,实现分布式日志层面的链路追踪,并且工具支持SpringMVC,Dubbo,OpenFe...
    99+
    2023-03-01
    Java gRPC拦截器 Java 分布式日志链路追踪
  • Dubbo实现分布式日志链路追踪
    技术场景 在日常的开发、测试或运维的过程中,经常存在这样的场景,开发人员在代码中使用日志工具(log4j、slf4j)记录日志,比如请求ID、IP等,方便在线上快速、精准的定位问题,...
    99+
    2024-04-02
  • ASP.Net Core中的日志与分布式链路追踪
    目录.NET Core 中的日志控制台输出非侵入式日志Microsoft.Extensions.LoggingILoggerFactoryILoggerProviderILogger...
    99+
    2024-04-02
  • 如何使用分布式链路追踪
    这篇文章主要介绍“如何使用分布式链路追踪”,在日常操作中,相信很多人在如何使用分布式链路追踪问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用分布式链路追踪”的疑惑有所帮...
    99+
    2024-04-02
  • ASP.Net Core中日志与分布式链路追踪的示例分析
    这篇文章主要介绍了ASP.Net Core中日志与分布式链路追踪的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。.NET Core 中的日志控制台输出最简单...
    99+
    2023-06-29
  • Go 分布式链路追踪实现原理解析
    目录为什么需要分布式链路追踪系统微服务架构给运维、排障带来新挑战分布式链路追踪系统如何帮助我们分布式链路追踪系统架构概览核心概念一般架构协议标准和开源实现应用侧调用链跟踪实现方案概览...
    99+
    2024-04-02
  • java 如何实现日志追踪MDC
    目录java 日志追踪MDC简单的demoMDC的介绍及使用1、MDC是什么?2、MDC的原理3、MDC的使用java 日志追踪MDC MDC ( Mapped Diagnostic...
    99+
    2024-04-02
  • Go分布式链路追踪实现原理是什么
    本文小编为大家详细介绍“Go分布式链路追踪实现原理是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“Go分布式链路追踪实现原理是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。为什么需要分布式链路追踪系统微...
    99+
    2023-07-02
  • gRPC超时拦截器如何实现
    这篇文章主要介绍“gRPC超时拦截器如何实现”,在日常操作中,相信很多人在gRPC超时拦截器如何实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”gRPC超时拦截器如何实现”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-07-02
  • 微服务分布式架构实现日志链路跟踪的方法
    Logback 背景 Logback是由log4j创始人设计的另一个开源日志组件,官方网站:http://logback.qos.ch。它当前分为下面下个模块: logba...
    99+
    2024-04-02
  • .NET Core分布式链路追踪框架的基本实现原理
    目录分布式追踪什么是分布式追踪分布式系统分布式追踪分布式追踪有什么用呢Dapper分布式追踪系统的实现跟踪树和 spanJaeger 和 OpenTracingOpenTracing...
    99+
    2024-04-02
  • .NET Core分布式链路追踪框架的实现原理是什么
    本文小编为大家详细介绍“.NET Core分布式链路追踪框架的实现原理是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“.NET Core分布式链路追踪框架的实现原理是什么”文章能帮助大家解决疑惑,下面跟着小编的思路...
    99+
    2023-06-29
  • Python 如何实现分布式日志记录?
    在现代应用程序的开发中,记录日志是非常重要的一项任务。日志记录可以帮助开发人员快速发现和解决程序中的问题。在分布式系统中,日志记录变得更加复杂,因为日志不仅需要记录每个节点的信息,还需要记录节点之间的交互信息。本文将介绍如何使用 Pyth...
    99+
    2023-07-22
    日志 分布式 函数
  • SpringBoot 2.5.5整合轻量级的分布式日志标记追踪神器TLog的详细过程
    目录项目整合项目结构添加依赖logback-spring.xml请求类ControllerSpanId的生成规则 TLog业务标签演示示例1示例二示例三示例四示例五 随着微...
    99+
    2022-11-13
    SpringBoot 2.5.5整合轻量级 SpringBoot分布式日志标记追踪TLog
  • Java SpringMVC如何实现自定义拦截器
    本篇内容主要讲解“Java SpringMVC如何实现自定义拦截器”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java SpringMVC如何实现自定义拦截器”吧!Spri...
    99+
    2023-06-29
  • PHP接口如何实现分布式日志管理?
    在分布式系统中,日志管理是一项非常重要的任务。日志管理可以帮助我们快速定位系统中的问题,排除故障,提高系统的可靠性。在PHP接口中,如何实现分布式日志管理呢?本文将详细介绍。 一、什么是分布式日志管理? 分布式日志管理是指在分布式系统中,...
    99+
    2023-06-27
    接口 分布式 日志
  • 如何使用Python实现分布式系统中的二维码追踪功能?
    分布式系统中的二维码追踪功能是一个非常有用的功能,它可以让我们追踪二维码的使用情况,以便更好地管理和优化我们的业务。在本文中,我们将介绍如何使用Python实现分布式系统中的二维码追踪功能。 一、了解二维码追踪功能的原理 在分布式系统中,我...
    99+
    2023-10-02
    关键字 二维码 分布式
  • 分布式对象存储方案,如何实现日志记录?
    随着云计算和大数据时代的到来,分布式对象存储方案越来越受到关注。在这个方案中,日志记录是非常重要的一项功能。本文将介绍分布式对象存储方案中日志记录的实现方法,并且演示代码。 一、什么是分布式对象存储方案? 分布式对象存储方案是指通过多台服...
    99+
    2023-07-28
    日志 分布式 对象
  • 如何利用PHP接口实现高效的分布式日志管理?
    随着互联网和移动互联网的快速发展,大量的数据被生成和记录,这些数据对于企业的经营和管理都具有非常重要的意义。其中,日志数据作为一种重要的信息资源,被广泛地应用于系统监控、故障排查、性能分析等领域。然而,对于大规模的日志数据,传统的单机存储和...
    99+
    2023-06-27
    接口 分布式 日志
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作