MyPerf4J: 一个针对高并发、低延迟应用设计的高性能且无侵入的实时 Java 方法性能监控和统计工具 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要在回答技术问题时复制粘贴 AI 生成的内容
ThinkHigher
V2EX    程序员

MyPerf4J: 一个针对高并发、低延迟应用设计的高性能且无侵入的实时 Java 方法性能监控和统计工具

  •  
  •   ThinkHigher
    LinShunKang 2018-07-30 08:57:35 +08:00 5681 次点击
    这是一个创建于 2635 天前的主题,其中的信息可能已经有所发展或是发生改变。

    MyPerf4J

    一个针对高并发、低延迟应用设计的高性能、无侵入的 Java 方法性能监控和统计工具。 受 perf4jTProfiler启发而来。

    MyPerf4J 具有以下几个特性:

    • 无侵入: 采用 JavaAgent 方式,对应用程序完全无侵入,无需修改应用代码
    • 高性能: 性能消耗非常小,每次记录只花费 73ns,可以在生产环境长期使用
    • 低内存: 采用内存复用的方式,整个生命周期只产生极少的临时对象,不影响应用程序的 GC
    • 高精度: 采用纳秒来计算响应时间
    • 高实时: 支持秒级监控,最低 1s!

    文档

    可视化

    • 目前 MyPerf4J 已提供Grafana Dashboard进行数据展示 Markdown Markdown

      想知道如何实现上述效果?请先按照快速启动的描述启动应用,再按照这里的描述进行安装配置即可。

    快速启动

    MyPerf4J 采用 JavaAgent 配置方式,透明化接入应用,对应用代码完全没有侵入

    打包

    • git clone [email protected]:ThinkpadNC5/MyPerf4J.git
    • mvn clean package
    • 把 MyPerf4J-ASM-${MyPerf4J-version}.jar 重命名为 MyPerf4J-ASM.jar

    配置

    在 JVM 启动参数里加上以下两个参数

    -javaagent:/your/path/to/MyPerf4J-ASM-${MyPerf4J-version}.jar -DMyPerf4JPropFile=/your/path/to/myPerf4J.properties

    其中,MyPerf4JPropFile的配置如下:

    #配置 PerfStatsProcessor,可不配置,用于自定义统计数据的处理 #PerfStatsProcessor=cn.perf4j.demo.MyPerfStatsProcessor #配置备份 Recorders 的数量,默认为 1,最小为 1,最大为 8,当需要在较小 MillTimeSlice 内统计大量方法性能数据时可配置大一些 BackupRecordersCount=1 #配置 Record 模式,可配置为 accurate/rough RecorderMode=accurate #配置时间片,单位为 ms,最小 1s,最大 600s MillTimeSlice=10000 #需要监控的 package,可配置多个,用英文';'分隔 IncludePackages=cn.perf4j.demo #不需要监控的 package,可配置多个,用英文';'分隔 ExcludePackages=org.spring; #可配置多个方法名,用英文';'分隔 ExcludeMethods=equals;hash #是否排除私有方法,true/false ExcludePrivateMethod=true #通用的方法执行时间阈值,单位为 ms ProfilingTimeThreshold=1000 #在一个时间片内,超过方法执行时间阈值的次数,仅在 RecorderMode=accurate 时有效 ProfilingOutThresholdCount=10 

    想了解更多的配置?请看这里

    运行

    • 输出结果,默认输出到 stdout.log:

      MyPerf4J Performance Statistics [2018-07-01 23:40:23, 2018-07-01 23:40:24] Api[2/3] RPS Avg(ms) Min(ms) Max(ms) StdDev Count TP50 TP90 TP95 TP99 TP999 TP9999 TP99999 TP100 DemoServiceImpl.getId1 7454181 0.00 0 0 0.00 7454181 0 0 0 0 0 0 0 0 DemoServiceImpl.getId2 7454180 0.00 0 0 0.00 7454180 0 0 0 0 0 0 0 0 

      定制你的输出结果?请看这里

    卸载

    在 JVM 启动参数中去掉以下两个参数,重启即可卸载此工具。

    -javaagent:/your/path/to/MyPerf4J-ASM.jar -DMyPerf4JPropFile=/your/path/to/myPerf4J.properties

    问题

    如果您遇到任何问题或有疑问,请您毫不犹豫的提交 Issue : )

    更多信息

    想更深入的了解 MyPerf4J ?请看https://github.com/ThinkpadNC5/MyPerf4J/wiki/Chinese-Doc

    PS: 如果觉得写得还行,请**star**这个项目,让更多人了解和使用MyPerf4J :) 。

    31 条回复    2018-08-02 09:54:25 +08:00
    ThinkHigher
        1
    ThinkHigher  
    OP
       2018-07-30 08:58:24 +08:00
    欢迎大家留言: )
    alamaya
        2
    alamaya  
       2018-07-30 09:18:41 +08:00
    Mark
    ghos
        3
    ghos  
       2018-07-30 09:27:09 +08:00 via Android   1
    赞啊!
    omygod
        4
    omygod  
       2018-07-30 10:49:03 +08:00   1
    厉害
    NotNil1
        5
    NotNil1  
       2018-07-30 10:57:42 +08:00
    赞,就是看到 4J 就有种尴尬的感觉。
    woodface2233
        6
    woodface2233  
       2018-07-30 11:31:20 +08:00 via iPhone   1
    zifangsky
        7
    zifangsky  
       2018-07-30 11:35:34 +08:00
    Mark
    tempdban
        8
    tempdban  
       2018-07-30 11:37:33 +08:00 via Android   1
    nb
    pythonee
        9
    pythonee  
       2018-07-30 12:52:43 +08:00
    是以方法为单位进行监控么
    ThinkHigher
        10
    ThinkHigher  
    OP
       2018-07-30 13:04:40 +08:00 via iPhone
    @pythonee 是的
    ThinkHigher
        11
    ThinkHigher  
    OP
       2018-07-30 13:04:57 +08:00 via iPhone
    @ljtletters 为啥?
    seaswalker
        12
    seaswalker  
       2018-07-30 13:44:52 +08:00   1
    momuou
        13
    momuou  
       2018-07-30 13:46:50 +08:00   1
    NotNil1
        14
    NotNil1  
       2018-07-30 14:22:13 +08:00
    @ThinkHigher 你知道 4j 是什么意思吗?
    JsonTu
        15
    JsonTu  
       2018-07-30 15:09:28 +08:00 via iPhone
    Mark,回头试试
    ThinkHigher
        16
    ThinkHigher  
    OP
       2018-07-30 19:11:07 +08:00 via iPhone
    @ljtletters 在我看来是 For Java,不知还有啥解释?
    NotNil1
        17
    NotNil1  
       2018-07-30 19:18:10 +08:00
    @ThinkHigher 我也是今天才去了解,就这个意思吧,但是看得很多了,感觉还是多平台适配才会起这种名字吧,同名项目区别为哪种言服务的。
    ThinkHigher
        18
    ThinkHigher  
    OP
       2018-07-30 23:11:01 +08:00 via iPhone
    @ljtletters MyPerf4J 的名字由来是这样子的:我所在的公司之前使用 perf4j 对一些接口做性能监控,后来服务化拆分以后 perf4j 得性能指标不能满足我的需求,然后我就想开发一个监控工具替换 perf4j,所以就起了 MyPerf4J 这个名字 : )
    tianzx
        19
    tianzx  
    PRO
       2018-07-31 09:12:16 +08:00 via Android
    mark
    wingyiu
        20
    wingyiu  
       2018-07-31 09:29:57 +08:00
    内置了些什么指标的监控?
    NotNil1
        21
    NotNil1  
       2018-07-31 09:49:06 +08:00
    @ThinkHigher 这样看起来就合理多了
    ThinkHigher
        22
    ThinkHigher  
    OP
       2018-07-31 12:55:38 +08:00 via iPhone
    wingyiu
        23
    wingyiu  
       2018-07-31 13:25:03 +08:00
    @ThinkHigher 支持什么框架?
    wingyiu
        24
    wingyiu  
       2018-07-31 14:42:39 +08:00
    micrometer 了解一下,感觉比这个叼多了
    ThinkHigher
        25
    ThinkHigher  
    OP
       2018-07-31 19:30:45 +08:00
    @wingyiu MyPerf4J 是利用 ASM 对 Java 方法的字节码进行注入实现 AOP 的,理论上支持所有 Java 代码,只不过需要针对一些容器做兼容处理,目前已经针对 tomcat 和普通 main 方法启动的程序做了兼容处理。
    ThinkHigher
        26
    ThinkHigher  
    OP
       2018-07-31 19:32:52 +08:00
    @wingyiu micrometer 了解了一下,micrometer 是和 Spring 继承在一起的,无法针对非 Spring 的应用做监控,如果没有理解错的话 : )
    wingyiu
        27
    wingyiu  
       2018-08-01 18:48:17 +08:00
    @ThinkHigher 你的这些功能 pinpoint 都有,而且不止支持 tomcat,还支持 dubbo ; micrometer 可以支持自定义指标,而且提供了 spring boot 的快速继承:)
    ThinkHigher
        28
    ThinkHigher  
    OP
       2018-08-01 19:22:41 +08:00 via iPhone
    @wingyiu pinpoint 有 TP99 ?
    wingyiu
        29
    wingyiu  
       2018-08-01 20:10:24 +08:00
    @ThinkHigher tp99 没听过 p99 倒是听过 我们是写程序从 pinpoint 聚合导出到指标系统的 什么聚合都可以加
    ThinkHigher
        30
    ThinkHigher  
    OP
       2018-08-01 20:17:08 +08:00 via iPhone
    @wingyiu TP99 和 P99 应该是一个意思,你可以对比一下 MyPerf4J 和 Pinpoint 以及 micrometer 在高负载下的性能消耗: )
    另:MyPerf4J 理论上支持所有 Java 应用,不需要和 Spring 集成,毕竟不是所有 Java 应用都使用 Spring : )
    wingyiu
        31
    wingyiu  
       2018-08-02 09:54:25 +08:00
    @ThinkHigher 得 你这个最牛逼
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     1177 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 26ms UTC 23:38 PVG 07:38 LAX 16:38 JFK 19:38
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86