gRPC的请求追踪神器go tool trace

gRPC的请求追踪

前言

我们来回顾一下之前分享的知识点:

介绍了基本你的gRPC的使用方式,框架,交互方式等

分享了gRPC的四种认证方式中重要的2种方式,有兴趣可以点击看看哦

整理了openssl 证书的生成,关键点已经高亮标注,值得一看

gRPC生态中的中间件,主要是做统一认证工作,不必要在每一个接口中都写一次认证方式

文章中有分享gRPC的各种功能的中间件,有兴趣可以点击链接,大佬们还请不吝赐教

go tool trace

今天我们来介绍一下go的请求追踪,也就是说go Trace ,分享trace有如下几个原因:

  • 学习完trace之后,你能够自己去实践,清晰的了解整个程序的调用栈
  • 可以通过追踪器捕获大量信息,如图

  • 可以更快的解决我们项目中的疑难杂症

我们或许都有这样的体会,自己思考明白,设计出来的程序,可以很清晰明了的将细节解释明白,对功能的增删改也是可以做到灵活应对。

可是让我们一下子去修改别人写的功能或模块的时候,很多时候会一脸懵逼,这也不敢动,那也不敢动,在不理解的情况下,有疑问,一定要问清楚原理和逻辑,否则搞不好就是线上问题。

如上情况,最重要的一个原因就是自己对当前模块/功能的熟悉程度,以及自己的思维模型是否可迁移。

总而言之,对程序,要有敬畏之心,好奇之心,持之以恒专研下去,要有解决问题的决心。

用go tool trace具体哪些地方合适,哪些地方不合适?

不合适

  • 运行缓慢的函数,或者找到大部分CPU时间花费在哪里,术业有专攻,看CPU时间花费,是有专门的工具的 go tool pprof

合适

  • 找出程序在一段时间内正在做什么
  • go tool trace 可以通过 view trace链接提供的其他可视化功能,对于诊断争用问题帮助极大
  • </
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
gRPC拦截器中实现gRPC请求的内部转发,可以使用gRPC提供的Stub对象来发送gRPC请求。首先,需要在代码中注入Stub对象,代码如下: ```java @Autowired private XxxServiceGrpc.XxxServiceBlockingStub xxxServiceBlockingStub; ``` 然后,在拦截器中使用Stub对象来发送gRPC请求,代码如下: ```java public <ReqT, RespT> ServerCall.Listener<ReqT> interceptCall(ServerCall<RespT, ReqT> call, Metadata headers, ServerCallHandler<ReqT, RespT> next) { // 获取请求的方法名称和参数 String methodName = call.getMethodDescriptor().getFullMethodName(); ReqT request = call.getMessage(); // 构造请求的上下文 Context.CancellableContext withCancellation = Context.current().withCancellation(); withCancellation.attach(); // 发送gRPC请求并获取响应结果 RespT response = xxxServiceBlockingStub.withDeadlineAfter(5, TimeUnit.SECONDS).withInterceptors(new HeaderClientInterceptor(headers)).execute(request); // 返回gRPC响应结果给调用方 return new ServerCall.Listener<ReqT>() {}; } ``` 在这段代码中,我们使用Stub对象向目标gRPC服务发送gRPC请求,并将请求头和参数传递过去。然后,我们将目标gRPC服务的响应结果返回给调用方。 需要注意的是,在发送gRPC请求时,我们可以使用`withDeadlineAfter()`方法设置请求的超时时间,以避免请求一直阻塞。另外,我们还可以使用`withInterceptors()`方法设置请求的拦截器,以添加自定义的请求头等信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值