pinpoint代码级的监控?

发布于 2022-09-11 18:17:33 字数 1267 浏览 17 评论 0

问题

最近在看dapper论文,同时本地跑了一把pinpoint,发现pinpoint的代码级别的监控很爽,翻看源代码缺没有找到这部分,可能是pinpoint以数字来代表method导致我没有看懂,大牛帮忙分析一波

相关代码

@RequestMapping("view")
@RestController
public class ViewController {
    @Resource
    private Reson reson;
    
    @RequestMapping(method = RequestMethod.GET)
    @ResponseBody
    public Object detail(HttpServletRequest request) throws InterruptedException {
        Thread.sleep(1000L);
        reson.rrr();
        reson.ddd();
        TestVo testVo = new TestVo();
        testVo.setName("ccc");
        return testVo;
    }
}
@Service
public class Reson {
    public void rrr() throws InterruptedException {
        Thread.sleep(1000L);
        TestVo testVo = new TestVo();
        testVo.setName("chen");
        System.out.println(new Gson().toJson(testVo));
        Thread.sleep(1000L);
    }

    public void ddd() throws InterruptedException {
        Thread.sleep(1000L);
    }
}

监控结果:

clipboard.png

我的推测是进入一个method的时候,将 span push到调用栈中,但是这种想法却有一个缺点,需要经过agent到转换,才能产生一次push,这里的 ddd() 方法及其方法内部很明显是没有这样的监控的,所以感到一定的迷茫,望大牛解答一波

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文