Java方法跟踪工具,Java Debug工具,Java方法耗时统计工具,方便你了解各种开源框架的源码
大家最阅读源码常用的手段应该是借助开发工具debug?又或者是把log4j的基本改成debug?今天要和大家分享一个帮助你更好地阅读源码神器,瞬间让你知道某个方法调用的所有方法栈(如果你想记录SpringBoot2.0的启动过程所有执行到的方法,必须调整JVM参数,不然随时OOM了),非常详细地记录了所有被调用到的方法及其耗时。下面具体了解一下:
一:Java Spy
Java Spy是一个独立的Jar包,以-javaagent的方式运行,会跟踪和记录设定方法的所有方法的调用过程及其耗时。
二:Spy Demo
Spy Demo是基于SpringBoot2.0的项目,集成了springweb和mybatis。基于这个项目我们来看看SpringBoot2.0的启动过程以及一个Http Call的执行过程。现在看看如何配置并运行Spy Demo:
(1) 配置Idea和 Java程序的JVM参数
-javaagent:C:\Users\Jo\IdeaProjects\java-spy\java-spy.jar -Xms4096m -Xmx4096m
(2)配置需要忽略的包名
SPY_IGNORE_FILE是固定的,spy_ignores.txt的路径可以随意改,下面看看spy_ignores.txt中忽略了哪些package:
com.fasterxml
org.aspectj
io.opentracing
ch.qos.logback
org.hibernate
org.jboss
org.springframework.util
org.springframework.jmx
org.springframework.format
org.springframework.boot.logging
org.springframework.expression
org.springframework.asm
org.springframework.cglib
org.apache
org.slf4j
com.sun
sun
java
在跟踪SpringBoot的启动过程的时候,我忽略了以上不太想关心的package,一般情况,jdk相关的包,log日志相关的包,json包忽略掉就好了。
三:Spy Web
启动Spy Web之前需要执行spy.sql,数据存储路径和数据库的连接信息:
到此,需要配置的信息已经完成。接下来就可以运行Spy Demo和Spy Web了。启动完成后,访问:http://127.0.0.1:16688/
点击sequence可以查看SpringBoot启动的时候方法调用详细信息(由于信息量大,这个页面打开需要15min+):
上图中,蓝色方法名表示还可以继续点击查看其方法调用细节。
视频介绍:https://mp.weixin.qq.com/s/ruEVZ0ZAkJlr90Tk56PefA
原文:https://www.cnblogs.com/jovic/p/13472901.html