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

3,154 阅读4分钟

banner窄.png

铿然架构  |  作者  /  铿然一叶 这是铿然架构的第 5 篇原创文章

相关阅读:

萌新快速成长之路
如何编写软件设计文档
JAVA编程思想(一)通过依赖注入增加扩展性
JAVA编程思想(二)如何面向接口编程
JAVA编程思想(三)去掉别扭的if,自注册策略模式优雅满足开闭原则
JAVA编程思想(四)Builder模式经典范式以及和工厂模式如何选?
Java编程思想(七)使用组合和继承的场景
JAVA基础(一)简单、透彻理解内部类和静态内部类
JAVA基础(二)内存优化-使用Java引用做缓存
JAVA基础(三)ClassLoader实现热加载
JAVA基础(四)枚举(enum)和常量定义,工厂类使用对比
JAVA基础(五)函数式接口-复用,解耦之利刃
Seata源码(一)初始化
Seata源码(二)事务基础对象
Seata源码(三)事务处理类结构和流程
Seata源码(四)全局锁GlobalLock
Seata源码(五)Seata数据库操作
Seata源码(六)Seata的undo日志操作
Seata源码(七)Seata事务故障处理
Seata源码(八)Seata事务生命周期hook
Seata源码(九)TCC核心类和处理逻辑
Seata源码(十)RM接收到请求后的调用过程
Seata源码(十一)TC接收到请求后的处理过程\


一、调用链跟踪的作用

调用链跟踪包括
1.前端到后端的调用链
2.单个服务内部方法之间的调用链
3.微服务之间的调用链
4.应用服务和数据库之间的调用链
5.应用服务和第三方服务中间的调用链,例如Redis,MQ

调用链跟踪的作用有:
1.定位多个微服务调用故障时哪个是故障点。
2.性能分析 3.SQL分析 4.方法或服务调用合理性分析 5.调用逻辑和数据流分析,这点对于新人特别有用,看了调用链和执行SQL就知道具体做了啥

二、调用链跟踪的需求

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


1.前端到后端以及多个微服务之间需要将调用信息传递过去,否则调用链会断掉
2.每个微服务要能获取到调用栈,注意调用栈和调用顺序不同,仅仅获取调用顺序是不够的,试比较:

左图只体现了调用顺序,没有体现调用栈信息,而右图既体现了调用顺序又体现了调用栈信息。
3.微服务内部的调用信息要能传递,并且做到无侵入 4.和数据库交互的微服务要能获取到调用的SQL

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

  1. 调用信息传递,这个信息可以通过http消息头传递
  1. 前端只要在发送请求时设置就好。不过通常一般不跟踪前端的调用耗时,因为那样会多一次网络交互。
  2. 对于微服务需要拦截request请求将调用链信息设置到消息头中,在spring中可以通过写RestTemplate拦截器和Fegin拦截器来实现。
  1. 微服务中调用栈的获取,使用spring的开发者会很自然想到用AOP来拦截,但是spring AOP拦截同一个类的多个方法之间的调用很不方便,有侵入性,因此并不适合。最好的方式是使用javaagent,通过代码注入的方式来拦截。
  2. 微服务内部调用信息传递需要通过线程范围的变量来传递,Java中的ThreadLocal已经提供了这个能力。
  3. 调用栈的跟踪Java也提供了这个能力,可以获得当前方法的调用栈信息。
  4. SQL监控,对于使用mybatis的会想到用mybatis的拦截器,这种方式有的情况下会不工作(原因未明),并且依赖mybatis,因此应用更底层的方法去拦截SQL,一种方式是自行实现JDBC代理类,另一种方式是使用第三方开源的SQL监控工具。
    end.