分享一个无代码侵入的开源 Java APM

2017-01-03 13:17:33 +08:00
 ArcherFeel
https://github.com/ArcherFeel/awacs

无需修改代码或依赖引入什么的, 通过 java agent 加载. 基础功能统计服务调用栈花费时间,频率以及异常警报什么的.
UI 部分因为跟公司业务比较紧密所有没有开源.
3064 次点击
所在节点    分享创造
8 条回复
sevncz
2017-01-06 15:56:48 +08:00
star 一记
ArcherFeel
2017-01-06 16:12:10 +08:00
@sevncz 感谢, 也欢迎各种 issue 和 pr 帮助提升和改进.
mifly
2017-01-06 23:39:24 +08:00
不是有个 Pinpoint 吗? https://github.com/naver/pinpoint
ArcherFeel
2017-01-06 23:54:59 +08:00
@mifly 是的, 之前有了解过, 不过 pinpoint 本身代码比较大, agent 端对应用本身的性能影响也不小, 且只能用 HBase 存储上报数据. 感觉不是我们想要的, 所以我们自己造了个轮子.
mifly
2017-01-07 07:56:15 +08:00
Pinpoint 那点代码还大?
Pinpoint 对性能做了不少优化了

你们做了哪些事情是比 Pinpoint 好的?
ArcherFeel
2017-01-07 18:03:04 +08:00
@mifly pinpoint 一共有 250M 的源代码, 这个数字不止是 agent 端的, 还包含 server 和 ui 部分, 不过也很大了. pinpoint 因为想做的更加灵活的缘故所以每种字节码的修改都是一个插件, 插件如果多了就会显得比较臃肿. 我不是很严格的做了下测试发现 pinpoint 对应用的影响还是不小的. 我们没有做的那么灵活, 主要的方法调用栈监控功能集中在一个插件中, 更加适合自身的业务, 另外数据上报部分不保证每次上报都百分之百收到, 做成了 agent 发送不需要回执, 所以网络方面的性能提高了一点. 至于哪里做的比 pinpoint 好这个我就不好说了, 毕竟 pinpoint 出来很久了, 已经很成熟, 我们只是做了一个更适合自身业务场景的更轻量级的东西, 原理是一样的.
psnail
2017-02-16 15:37:15 +08:00
嗯,我认为 pinpoint 已经很成熟了,各个方面都考虑到了。而且很多特性正在开发。
我们线上也使用了 pinpoint ,发现性能损耗并不是很大,只有 3%左右,和业务相关吧。
另外,安利下 pinpoint nodejs agent , https://github.com/peaksnail/pinpoint-node-agent

目前线上主要是 java+nodejs ,所以开发了 node-agent
irockytan
2017-07-27 21:30:49 +08:00
@ArcherFeel 炮儿

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/331885

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX