Java Spy-代码跟踪神器

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+):

 

 上图中,蓝色方法名表示还可以继续点击查看其方法调用细节。

推荐一款项目管理工具:http://www.itproject-manager.com/

 

更多信息关注公众号:

posted on 2020-08-10 23:15  itproject-manager  阅读(1093)  评论(0编辑  收藏  举报