Arthas 开源工具实战
Arthas
是Alibaba开源的Java诊断工具,深受开发者喜爱。
当你遇到以下类似问题而束手无策时,Arthas
可以帮助你解决:
- 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
- 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
- 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
- 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
- 是否有一个全局视角来查看系统的运行状况?
- 有什么办法可以监控到JVM的实时运行状态?
0.arthas启动安装参考arthas官网教程
1. 先启动一个java项目
上节我打出了一个jar文件,现在直接先执行起来: java -jar arthas-demo.jar
2. 启动arthas
执行命令:java -jar arthas-boot.jar
输入exit,可以先退出当前的dashboard命令。
3. arthas的其他一些命令
附录我的源码:
arthas可以根据一个Jar包就可以反编译出,跟我源码基本一样的代码。真的是太可怕了。
调用栈命令:stack (运行此命令之后需要即时触发方法才会有响应的信息打印在控制台上)
运行命令:stack demo.GameTest sayHello,可以看到实时的调用栈信息如下:
运行命令:stack com.JXWork.facade.impl.LJUserFacadeServiceImpl selecilserDeta ,可以看到实时的调用栈信息如下:
4. 实战arthas一个本地Tomcat作为服务器的Java Web工程
先启动本地的工程,然后在下面可以看到一个Tomcat服务器的应用,如下:
5. 退出arthas
如果只是退出当前的连接,可以用quit
或者exit
命令。Attach到目标进程上的arthas还会继续运行,端口会保持开放,下次连接时可以直接连接上。
如果想完全退出arthas,可以执行shutdown
命令。