jvm在线诊断工具greys
所属分类 java
浏览量 1272
可跟踪指定方法堆栈及耗时 性能优化时很有用
Greys-Anatomy取名同名美剧“实习医生格蕾”
同类工具
BTrace 脚本编写学习成本很高,且容易出错。容易搞挂系统
2012年淘宝的聚石写了HouseMD,将常用的几个Btrace脚本整合在一起形成一个独立风格的应用,但其核心代码用的是Scala
HouseMD相比BTrace最强大的地方就在于能快速指定拦截的类与方法,但却无法支持对观察到的对象进行展开、条件过滤等操作。
远程DEBUG最大的问题就在于,只允许一个人访问DEBUG端口,而且一单断点条件设置不当,很有可能将其他正常的业务请求拦下,影响其他用户的使用。
Greys采用的思路是做观察者,其所设置的断点不会阻塞正常业务的流程,但可以观察到断点所拦截到的所有信息。
Greys
目标类与Greys ClassLoader隔离
高性能 ASM 字节码增强
纯Java编写 专业的JVM的业务问题定位工具
在线安装(推荐)
curl -sLk http://ompc.oss.aliyuncs.com/greys/install.sh|sh
./greys.sh $JVMPID [@IP:PORT]
IP和PORT,默认127.0.0.1和3658
help Display Greys Help
session Display current session information
version Display Greys version
jvm Display the target JVM information
top Display The Threads Of Top CPU TIME
sc Search all the classes loaded by JVM
sm Search the method of classes loaded by JVM
monitor Monitor the execution of specified Class and its method
watch Display the details of specified class and method
tt Time Tunnel
stack Display the stack trace of specified class and method
ptrace Display the detailed thread path stack of specified class and method
trace Display the detailed thread stack of specified class and method
reset Reset all the enhanced classes
asm Display class bytecode by asm format
shutdown Shut down Greys server and exit the console
quit Quit Greys console
js Enhanced JavaScript
sc -df com.dyyx.dbview.JdbcUtils
class-loader
能显示class全路径就更好了
sm -d com.dyyx.dbview.JdbcUtils *
显示方法信息
| com.dyyx.dbview.JdbcUtils | declaring-class : class com.dyyx.dbview.JdbcUtils |
| | gaMethod-name : query |
| | modifier : public,static |
| | annotation : |
| | parameters : java.lang.String |
| | java.lang.String |
| | java.lang.String |
| | int |
| | return : com.dyyx.dbview.dto.Result |
| | exceptions : java.lang.Exception
monitor -c 20 com.dyyx.dbview.JdbcUtils query
统计周期20s,统计方法情况
20秒之后出统计结果
trace com.dyyx.dbview.WebUtils conntest
跟踪方法调用堆栈并统计耗时
`---+Tracing for : thread_name="http-bio-8580-exec-3" thread_id=0x11;is_daemon=true;priority=5;
`---+[1121,1121ms]com.dyyx.dbview.WebUtils:conntest()
+---[1,0ms]com.dyyx.dbview.Utils:getString(@53)
+---[1,0ms]com.dyyx.dbview.Utils:blank(@54)
+---[1,0ms]java.lang.String:trim(@58)
+---[1,0ms]com.dyyx.dbview.Utils:getDBConfigMap(@60)
+---[1115,1114ms]com.dyyx.dbview.Utils:getConn(@64)
+---[1121,6ms]java.sql.Connection:getTransactionIsolation(@65)
+---[1121,0ms]com.dyyx.dbview.JdbcUtils:getTransactionIsolation(@66)
+---[1121,0ms]java.lang.StringBuilder:(@67)
+---[1121,0ms]java.lang.StringBuilder:append(@67)
+---[1121,0ms]java.lang.StringBuilder:append(@67)
+---[1121,0ms]java.sql.Connection:getAutoCommit(@67)
+---[1121,0ms]java.lang.StringBuilder:append(@67)
+---[1121,0ms]java.lang.StringBuilder:toString(@67)
`---[1121,0ms]com.dyyx.dbview.JdbcUtils:close(@72)
tt -t -n 3 com.dyyx.dbview.WebUtils conntest
记录3次方法执行情况。
watch -bs com.dyyx.dbview.JdbcUtils query 'params[1] + "," + params[2]+ "," + params[3] + "," +returnObj'
查看方法的入参、返回值信息
参数下标从0开始
jvm
查看 jvm 信息
jvm启动参数 CLASS-PATH BOOT-CLASS-PATH
类加载信息 加载数 卸载数
GC信息 次数 耗时
PS Scavenge : 44/744(ms)
PS MarkSweep : 1/59(ms)
[count/time]
内存池信息 堆内堆外内存
+--------------------+----------------------------------------------------------------------------------------------------+
| MEMORY-MANAGERS | CodeCacheManager : Code Cache |
| | Metaspace Manager : Metaspace |
| | Compressed Class Space |
| | PS Scavenge : PS Eden Space |
| | PS Survivor Space |
| | PS MarkSweep : PS Eden Space |
| | PS Survivor Space |
| | PS Old Gen |
+--------------------+----------------------------------------------------------------------------------------------------+
| MEMORY | HEAP-MEMORY-USAGE : 229113856/134217728/1908932608/154049384 |
| | [committed/init/max/used] |
| | NO-HEAP-MEMORY-USAGE : 53575680/2555904/-1/45384880 |
| | [committed/init/max/used] |
| | PENDING-FINALIZE-COUNT : 0
线程信息
COUNT : 26
DAEMON-COUNT : 25
LIVE-COUNT : 29
STARTED-COUNT : 4904
上一篇
下一篇
spring5事件机制
红黑树要点整理
BeanFactory和ApplicationContext的区别
.profile 与 .bash_profile
spring5配置属性读取机制
spring5模块介绍