资讯专栏INFORMATION COLUMN

Java调用链跟踪关键技术(一)总体介绍

gaara / 1572人阅读

摘要:微服务中调用栈的获取,使用的开发者会很自然想到用来拦截,但是拦截同一个类的多个方法之间的调用很不方便,有侵入性,因此并不适合。调用栈的跟踪也提供了这个能力,可以获得当前方法的调用栈信息。

一、调用链跟踪的作用

调用链跟踪包括

1.前端到后端的调用链

2.单个服务内部方法之间的调用链

3.微服务之间的调用链

4.应用服务和数据库之间的调用链

5.应用服务和第三方服务中间的调用链,例如Redis,MQ

调用链跟踪的作用有:

1.定位多个微服务调用故障时哪个是故障点。

2.性能分析

3.SQL分析

4.方法或服务调用合理性分析

5.调用逻辑和数据流分析,这点对于新人特别有用,看了调用链和执行SQL就知道具体做了啥

二、调用链跟踪的需求

那么调用链跟踪涉及到需求有哪些,看图:

1.前端到后端以及多个微服务之间需要将调用信息传递过去,否则调用链会断掉

2.每个微服务要能获取到调用栈,注意调用栈和调用顺序不同,仅仅获取调用顺序是不够的,试比较:

左图只体现了调用顺序,没有体现调用栈信息,而右图既体现了调用顺序又体现了调用栈信息。

3.微服务内部的调用信息要能传递,并且做到无侵入

4.和数据库交互的微服务要能获取到调用的SQL

三、Java调用链跟踪涉及的关键技术

调用信息传递,这个信息可以通过http消息头传递

1) 前端只要在发送请求时设置就好。不过通常一般不跟踪前端的调用耗时,因为那样会多一次网络交互。

2) 对于微服务需要拦截request请求将调用链信息设置到消息头中,在spring中可以通过写RestTemplate拦截器和Fegin拦截器来实现。

微服务中调用栈的获取,使用spring的开发者会很自然想到用AOP来拦截,但是spring AOP拦截同一个类的多个方法之间的调用很不方便,有侵入性,因此并不适合。最好的方式是使用javaagent,通过代码注入的方式来拦截。

微服务内部调用信息传递需要通过线程范围的变量来传递,Java中的ThreadLocal已经提供了这个能力。

调用栈的跟踪Java也提供了这个能力,可以获得当前方法的调用栈信息。

SQL监控,对于使用mybatis的会想到用mybatis的拦截器,这种方式有的情况下会不工作(原因未明),并且依赖mybatis,因此应用更底层的方法去拦截SQL,一种方式是自行实现JDBC代理类,另一种方式是使用第三方开源的SQL监控工具。

end.

加入《Java栈实战营》知识星球,参与讨论,更多实战代码分享,不就是几斤苹果,几个荣耀道具的事吗!

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/75796.html

相关文章

  • Java调用跟踪关键技术(二)Javaagent

    摘要:一网上关于的介绍很多,请找度娘和谷兄。唯一提的一点是字节码注入比较好用的是,封装度很高,使用简单。二代码样例以下为关键代码样例,可以依样画瓢自行改造。加入栈实战营知识星球,参与讨论,更多实战代码分享,不就是几斤苹果,几个荣耀道具的事吗 一、Javaagent 网上关于Javaagent的介绍很多,请找度娘和谷兄。唯一提的一点是字节码注入比较好用的是bytebuddy,封装度很高,使用简...

    geekzhou 评论0 收藏0
  • Java调用跟踪关键技术(四)SQL监控

    摘要:一监控一般思路中监控一般通过代理模式实现,如下右边是接口类。配置将项目下文件放到目录下或者中,找到将类名修改为你自己的实现类,并去掉其他所有配置都不用修改就可以监控到。至此,可以监控到语句了。 一、SQL监控一般思路 Java中SQL监控一般通过代理模式实现,如下: showImg(https://segmentfault.com/img/bVbvWML?w=2187&h=1090)...

    ?xiaoxiao, 评论0 收藏0
  • Java调用跟踪关键技术(三)线程变量

    摘要:除了以上级别的成员变量共享,在调用链跟踪时要能识别不同分层下的多个类实例的调用是同一个请求,而这个请求的调用都在一个独立线程内完成,此时就要用到线程级变量共享。 一、Java类成员作用域 JAVA类成员作用域参考下图: showImg(https://segmentfault.com/img/bVbvWlh?w=1695&h=925); Java虚拟机级作用域,通过在类成员变量前加...

    ThreeWords 评论0 收藏0
  • Java调用跟踪关键技术(五)获取调用

    摘要:一调用栈调用链监控仅仅获取调用顺序是不够的,如前所描述左边只体现了顺序,右边体现了顺序和调用栈信息。二获取调用栈在中获取调用栈的方法如下代码示例输出结果可以看到第个栈是调用的方法。 一、调用栈 调用链监控仅仅获取调用顺序是不够的,如前所描述: showImg(https://segmentfault.com/img/bVbvV9H?w=500&h=230);左边只体现了顺序,右边体现...

    VPointer 评论0 收藏0

发表评论

0条评论

gaara

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<