MyPerf4J 2.0 正式发布!增加数十个 JVM 监控指标 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要在回答技术问题时复制粘贴 AI 生成的内容
ThinkHigher
V2EX    程序员

MyPerf4J 2.0 正式发布!增加数十个 JVM 监控指标

  •  
  •   ThinkHigher
    LinShunKang 2018-09-11 09:03:04 +08:00 2801 次点击
    这是一个创建于 2592 天前的主题,其中的信息可能已经有所发展或是发生改变。

    MyPerf4J

    Markdown

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

    MyPerf4J 具有以下几个特性:

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

    文档

    监控指标

    MyPerf4J 为每个应用收集数十个监控指标,所有的监控指标都是实时采集和展现的。

    下面是 MyPerf4J 目前支持的监控指标列表:

    • Method
      RPS,Count,Avg,Min,Max,StdDev,TP50, TP90, TP95, TP99, TP999, TP9999, TP99999, TP100 Markdown Markdown
    • JVM Thread
      TotalStarted,Runnable,Blocked,Waiting,TimedWaiting,Terminated,Active,Peak,Daemon,New Markdown

    • JVM Memory
      HeapInit,HeapUsed,HeapCommitted,HeapMax,NonHeapInit,NonHeapUsed,NonHeapCommitted,NonHeapMax Markdown

    • JVM GC
      CollectCount,CollectTime Markdown

    • JVM Class
      Total,Loaded,Unloaded 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的配置如下:

    #应用名称 AppName=MyPerf4JTest #MetricsProcessor 类型,0:以标准格式化结构输出到 stdout.log 1:以标准格式化结构输出到磁盘 2:以 InfluxDB LineProtocol 格式输出到磁盘 MetricsProcessorType=1 #配置各个 Metrics 日志的文件路径,可不配置 MethodMetricsFile=/data/logs/MyPerf4J/method_metrics.log #ClassMetricsFile=/data/logs/MyPerf4J/class_metrics.log #GCMetricsFile=/data/logs/MyPerf4J/gc_metrics.log #MemMetricsFile=/data/logs/MyPerf4J/memory_metrics.log #ThreadMetricsFile=/data/logs/MyPerf4J/thread_metrics.log #配置日志文件滚动时间间隔,分别有 MINUTELY、HOURLY 和 DAILY 三个值 LogRollingTimeUnit=HOURLY #配置备份 Recorders 的数量,默认为 1,最小为 1,最大为 8,当需要在较小 MillTimeSlice 内统计大量方法性能数据时可配置大一些 BackupRecordersCount=1 #配置 Record 模式,可配置为 accurate/rough RecorderMode=accurate #配置时间片,单位为 ms,最小 1s,最大 600s MillTimeSlice=10000 #是否展示方法参数类型 ShowMethodParams=true #需要监控的 package,可配置多个,用英文';'分隔 IncludePackages=cn.perf4j.demo #不需要监控的 package,可配置多个,用英文';'分隔 ExcludePackages=org.spring; #可配置多个方法名,用英文';'分隔 ExcludeMethods=equals;hash #是否排除私有方法,true/false ExcludePrivateMethod=true #通用的方法执行时间阈值,单位为 ms ProfilingTimeThreshold=1000 #在一个时间片内,超过方法执行时间阈值的次数,仅在 RecorderMode=accurate 时有效 ProfilingOutThresholdCount=10 

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

    运行

    • 输出结果,输出到 /data/logs/MyPerf4J/method_metrics.log:

      MyPerf4J Method Metrics [2018-09-06 19:21:40, 2018-09-06 19:21:45] Method[4] RPS Avg(ms) Min(ms) Max(ms) StdDev Count TP50 TP90 TP95 TP99 TP999 TP9999 TP99999 TP100 DemoServiceImpl.getId1(long) 1974 0.00 0 0 0.00 9870 0 0 0 0 0 0 0 0 DemoServiceImpl.getId2(long) 2995 0.50 0 2 0.01 14975 0 1 2 2 2 2 2 2 DemoServiceImplV2.getId1(long) 787 0.00 0 0 0.00 3938 0 0 0 0 0 0 0 0 DemoServiceImplV2.getId3(long) 1575 0.50 0 1 0.01 7876 1 1 1 1 1 1 1 1 

    卸载

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

    -javaagent:/your/path/to/MyPerf4J-ASM.jar

    -DMyPerf4JPropFile=/your/path/to/myPerf4J.properties

    问题

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

    更多信息

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

    4 条回复    2018-10-12 20:46:47 +08:00
    letitbesqzr
        1
    letitbesqzr  
       2018-09-11 09:56:15 +08:00
    666 赞
    googlefans
        2
    googlefans  
       2018-09-16 20:19:41 +08:00
    界面看起来高大上
    privil
        3
    privil  
       2018-09-21 12:58:24 +08:00
    有建什么群大家可以交流的么?
    ThinkHigher
        4
    ThinkHigher  
    OP
       2018-10-12 20:46:47 +08:00
    @privil 目前还没有建群的打算,如果有问题或者建议可以发邮件或者提 issue : )
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     1601 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 35ms UTC 16:20 PVG 00:20 LAX 09:20 JFK 12:20
    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