首页 > 编程语言 > 详细

Java Spy-代码跟踪神器

时间:2020-08-10 23:51:29      阅读:202      评论:0      收藏:0      [点我收藏+]

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

Java Spy-代码跟踪神器

原文:https://www.cnblogs.com/jovic/p/13472901.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!