关于Skywalking Agent customize-enhance-trace对应用复杂参数类型取值

对于Skywalking Agent customize-enhance-trace 大家应该不陌生了,主要支持以非入侵的方式按用户自定义的Span跟踪对应的应用方法,并获取数据。 参考https://skywalking.apache.org/docs/skywalking-java/v9.0.0/en/setup/service-agent/java-agent/customize-enhance-trace/

规则如下:

但实际应用的时候会遇到,待拦截的方法,参数类型非常复杂,例如

bash 复制代码
<enhanced>
<class class_name="com.seckill.seckillentity.seckill.seckillServiceImpl">
...
<method method="updateStdOrder(com.seckill.seckillentity.std.StdOrderMsg)" operation_name="/updateStdOrder" static="false">
...
</method>
</class>
</enhanced>

表示订单信息com.seckill.seckillentity.std.StdOrderMsg 的类包含,订单号,关联的用户编号和商品信息,而商品信息实际上是一个Hashmap类型

bash 复制代码
package com.seckill.seckillentity.std;
import java.io.Serializable;

public class StdOrderMsg implements Serializable{
    private String order_id;
    private Integer user_id;
    private LightFieldMap fields = new LightFieldMap();

    public String getOrder_id() {
        return order_id;
    }
    public void setOrder_id(String ordId){
        order_id=ordId;
    }
    public Integer getUser_id() {
        return user_id;
    }
    public void setUser_id(Integer userId) {
        user_id = userId;
    }
    public LightFieldMap getFields() {
        return this.fields;
    }
    public void setFields(LightFieldMap lightFields) {
        fields = lightFields;
    }
    public String toString() {
        ...
    }

而HashMap 由嵌套一层 fields

bash 复制代码
public class LightFieldMap implements Serializable {
    private final Map<String, Object> fields = new HashMap();
    private final Map<String, List<LightFieldMap>> groups = new HashMap();

    public LightFieldMap() {
    }
    ...
    public Object getFieldValue(String fName) {
        return this.fields.get(fName);
    }

    public void setFieldValue(String fName, Object value) {
        this.fields.put(fName, value);
    }
   ...

但需求是要拦截到商品信息具体数据,商品编号、价格、购买量,等等...

也就是说,要获取Hashmap内部fields具体域对应的据,该如何定义Tag表达式呢?

起初,按SW提供用户手册尝试,例如获取价格

arg0.getFields().'price'

但拦截的结果 price=null

然后尝试把Hashmap类用toString方法打印出来

arg0.getFields().toString()

发现可以获取清晰包信息:

观察该对象的结构,就很容易想到按以下方式获取

bash 复制代码
<tag key="pid">arg[0].getFields().fields.pid</tag>
<tag key="price">arg[0].getFields().fields.buy_price</tag>
<tag key="stock">arg[0].getFields().fields.buy_count</tag>

测试成功

总结: 对于复杂类,需要研究应用具体数据结构,如果是结构体嵌套,可以用A.B.C... 以此类推,但如果中间套了一层类似于HashMap对象,那就需要用类对应方法把该对象获取,然后再按结构体处理A.fun().B.C...,如果没有把握可以通过A.fun(),toString()把数据集拦截出来,然后再根据实际情况处理。

相关推荐
就改了13 天前
Windows 环境 SkyWalking 完整实操教程
windows·微服务·skywalking
Jul1en_13 天前
【SpringCloud】SkyWalking 链路追踪知识详解及部署教程
java·后端·spring·spring cloud·skywalking
SRETalk17 天前
SkyWalking / Jaeger / ARMS 已经有了,还需要统一可观测平台吗
skywalking·apm·jaeger·flashcat·arms
云烟成雨TD19 天前
Spring AI 1.x 系列【52】可观测集成 SkyWalking
人工智能·spring·skywalking
接着奏乐接着舞21 天前
springcloud skywalking
spring·spring cloud·skywalking
weixin_399380691 个月前
Tongweb7049m10适配skywalking(by lqw)
java·skywalking
未若君雅裁1 个月前
微服务监控与 SkyWalking 链路追踪
微服务·架构·skywalking
Jinkxs1 个月前
SkyWalking - Kafka _ RabbitMQ 消息链路追踪支持
kafka·rabbitmq·skywalking
heimeiyingwang1 个月前
【架构实战】链路追踪SkyWalking:让请求无所遁形
架构·skywalking
不懂的浪漫1 个月前
OpenTelemetry 和 SkyWalking Agent 怎么选?一次讲清 OTel、SkyWalking Agent 的相同点与区别
wpf·skywalking·链路追踪·opentelemetry·otel