SkyWalking 自定义链路追踪

对项目中的业务方法,实现链路追踪,方便我们排查问题

引入依赖

XML 复制代码
<!‐‐ SkyWalking 工具类 ‐‐> 
<dependency> 
    <groupId>org.apache.skywalking</groupId> 
    <artifactId>apm‐toolkit‐trace</artifactId> 
    <version>8.4.0</version> 
</dependency>

@Trace 注解业务方法

业务方法想在跟踪链路上显示出来,只需要在业务方法上加上@Trace注解即可

代码

java 复制代码
@RequestMapping("/list")
public Object list() {
    return orderService.list();
}
java 复制代码
@Service
public class OrderService {

    @Trace
    public List<User> list() {
        List<User> result = new ArrayList<>();
        result.add(new User(1, "用户1"));
        result.add(new User(2, "用户2"));
        return result;
    }
}

测试

http://127.0.0.1:8040/order/list

http://127.0.0.1:8040/order/list

@Tags或@Tag 记录额外信息

可以为追踪链路增加其他额外的信息,比如记录参数和返回信息

实现方式

在方法上增加@Tag或者@Tags

注解说明

@Tag :注解中 key = 方法名 ; value = returnedObj 返回值 arg[0] 参数

代码

java 复制代码
@Service
public class OrderService {

    @Trace
    @Tag(key = "list", value = "returnedObj")  // 返回值
    public List<User> list() {
        List<User> result = new ArrayList<>();
        result.add(new User(1, "用户1"));
        result.add(new User(2, "用户2"));
        return result;
    }

    @Trace
    @Tags({
            @Tag(key = "param", value = "arg[0]"),    // 第一个参数
            @Tag(key = "user", value = "returnedObj") // 返回值
    })
    public Object getById(Integer id) {
        return new User(id, "用户" + id);
    }
}

测试

返回值
参数 + 返回值

性能分析

新建任务

分析结果

发送 订单添加请求 查看分析结果

相关推荐
随风,奔跑3 天前
Spring Cloud Alibaba(六)-链路追踪SkyWalking
java·后端·spring·skywalking
tsyjjOvO4 天前
分布式事务 Seata 与链路追踪 SkyWalking 全解析
分布式·skywalking
小旭95274 天前
分布式事务 Seata 详解 + 链路追踪 SkyWalking 实战
java·分布式·后端·信息可视化·skywalking
dEso RSET11 天前
Skywalking介绍,Skywalking 9.4 安装,SpringBoot集成Skywalking
spring boot·后端·skywalking
身如柳絮随风扬15 天前
链路追踪SkyWalking 架构了解
架构·skywalking
洒满阳光的午后19 天前
我做了一个“能理解业务语义”的可观测性 MCP Server:统一接入 Prometheus、OpenObserve 和 SkyWalking
人工智能·ai·prometheus·skywalking·openobserve·mcp
梵得儿SHI19 天前
SpringCloud 实战落地:可观测性建设(SkyWalking + Prometheus + Grafana)从 0 到 1 生产级部署
grafana·prometheus·springcloud·skywalking·微服务可观测性·线上问题排查
Jinkxs21 天前
SkyWalking - Spring Cloud Alibaba 全链路追踪实战
skywalking
烛之武22 天前
Skywalking服务链路追踪与Jemeter压力测试
压力测试·skywalking
鬼先生_sir23 天前
Spring Cloud 微服务监控实战:SkyWalking + Prometheus+Grafana 全栈解决方案
运维·spring cloud·grafana·prometheus·skywalking