Spring Cloud —— SkyWalking(四)

8. 自定义追踪

skywalking 默认会追踪接口(如加了 @RequestMapping 的方法),如果想追踪程序中的其他方法就需要自定义追踪。

8.1 添加依赖

xml 复制代码
<dependency>
	<groupId>org.apache.skywalking</groupId>
	<artifactId>apm-toolkit-trace</artifactId>
	<version>9.4.0</version>
</dependency>

8.2 注解添加

这里以该接口,调用的 orderService.queryById() 方法进行自定义追踪。

在该方法上添加 @Trace 注解

java 复制代码
    @Override
    @Trace
    public OrderInfo queryById(Integer orderId) {
        return orderMapper.selectById(orderId);
    }

链路中就显示了该方法,鼠标放在上面还会有信息,点击后信息更详细,如下图

这里可以看到, 端点名称默认为 包名+类名+方法名(参数类型),在 @Trace 注解中给 operationName 属性赋值就可以指定名字。

java 复制代码
    @Override
    @Trace(operationName = "queryOrderById")
    public OrderInfo queryById(Integer orderId) {
        return orderMapper.selectById(orderId);
    }

如下图:

8.3 附加信息

通过 @Tag@Tags 可以在自定义链路追踪中附加关键业务或上下文信息的注解

@Tag 信息如下

可以看出,是按照键值对的形式存储信息的

java 复制代码
    @Override
    @Trace(operationName = "queryOrderById")
    @Tag(key = "orderId", value = "arg[0]")
    public OrderInfo queryById(Integer orderId) {
        return orderMapper.selectById(orderId);
    }

arg[i] 表示方法的参数,从 0 开始计算

@Tags 就是添加多个 @Tag

java 复制代码
    @Override
    @Trace(operationName = "queryOrderById")
     @Tags({
            @Tag(key = "orderId", value = "arg[0]"),
            @Tag(key = "orderinfo", value = "returnedObj")})
    public OrderInfo queryById(Integer orderId) {
        return orderMapper.selectById(orderId);
    }

returnedObj 即返回值

9. 性能剖析

性能剖析:针对分布式系统代码级性能的动态分析技术

前面只知道哪个端点很耗时,使用性能剖析,就可以精确到某一行代码的耗时多少,可以快速识别高耗时方法(如 慢SQL查询),定位 Trace 中具体 Span 的性能问题,针对性进行优化。

使用

新建任务

  • 端点名称:可以自行输入端点名称(不推荐),在点击后出现的下拉框中选择(如果未出现多刷新几次)
  • 监控时间:(monitor now)新建任务后就监视,(set start time)到了指定时间再开始监视
  • 监控持续时间:监控采样多长时间
  • 起始监控时间:多少秒后开始采集
  • 监控间隔:多长时间采样一次
  • 最大采样数:最大采集多少样本

创建完成后,如果点击任务出现了提示,说明还没采到样,如下图:

采到样后,选中你要看到,点击分析就能看到详细内容

看精确定位到代码行数

相关推荐
FQNmxDG4S7 小时前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言
虹科网络安全8 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje8 小时前
Java语法进阶
java·开发语言·jvm
rKWP8gKv78 小时前
Java微服务性能监控:Prometheus与Grafana集成方案
java·微服务·prometheus
老前端的功夫8 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_435287928 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
小江的记录本8 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
yaoxin5211239 小时前
397. Java 文件操作基础 - 创建常规文件与临时文件
java·开发语言·python
极客先躯11 小时前
高级java每日一道面试题-2025年11月24日-容器与虚拟化题[Dockerj]-runc 的作用是什么?
java·oci 的命令行工具·最小可用·无守护进程·完全标准·创建容器的核心流程·runc 核心职责思维导图
用户606487671889611 小时前
AI 抢不走的技能:用 Claude API 构建自动化工作流实战
java