arthas—线上debug好帮手

arthas简介

以下是arthas官网原文:

通常,本地开发环境无法访问生产环境。如果在生产环境中遇到问题,则无法使用 IDE 远程调试。更糟糕的是,在生产环境中调试是不可接受的,因为它会暂停所有线程,导致服务暂停。

开发人员可以尝试在测试环境或者预发环境中复现生产环境中的问题。但是,某些问题无法在不同的环境中轻松复现,甚至在重新启动后就消失了。

如果您正在考虑在代码中添加一些日志以帮助解决问题,您将必须经历以下阶段:测试、预发,然后生产。这种方法效率低下,更糟糕的是,该问题可能无法解决,因为一旦 JVM 重新启动,它可能无法复现,如上文所述。

Arthas 旨在解决这些问题。开发人员可以在线解决生产问题。无需 JVM 重启,无需代码更改。 Arthas 作为观察者永远不会暂停正在运行的线程。                        

 官网原文把功能写的已经很通透易懂了,我这边主要是补充一下它的用法和一些插件。

官网地址:简介 | arthas

用法介绍

1. 启动arthas

下载arthas-boot.jar,然后用java -jar的方式启动:

curl -O https://arthas.aliyun.com/arthas-boot.jar
java -jar arthas-boot.jar

启动之后arthas会将当前运行的所有应用都列举出来,如下:

 然后从1、2、3中选择一个进入,这里我选择3进入,但是报错了,没关系按照它第三条提示的命令重启一下 ,成功进入。

 这里的SpringBoot-query-0.0.1-SNAPSHOT.jar就是我写的一个测试应用。

2. 反编译java类

命令格式:jad 包路径+类名

3. 函数执行数据观测

这个一般使用它的watch指令,但是自己去拼实在是太麻烦了。下面介绍一个插件,如果你的开发工具是idea,那么可以去插件市场搜索arthas

 安装之后,打开编辑器,选中方法名,右键打开工具条

 这样就会生成一条监测命令,粘贴到刚才的arthas控制台即可,调用一下该方法,就可以看到出入参数了,非常的便捷好用。

watch指令使用的最多,多用于调试功能。

 4. 方法内部调用路径,并输出方法路径上的每个节点上耗时

使用idea插件生成方法的trace命令,贴到arthas控制台,如下:

这样就可以很清楚看到这个方法调用了哪些类、哪些方法并且把耗时打印出来了。 

5. 方法执行监控

使用idea插件生成方法的monitor命令,贴到arthas控制台,如下:

monitor命令一般用于统计方法的平均耗时。

  • 9
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 10
    评论
要在IDEA中进行线上代码的debug,可以按照以下步骤进行操作: 1. 确保本地IDEA环境和线上服务器的监听端口互通。这样才能成功连接到远程服务器。\[2\] 2. 在本地启动IDEA,并确保成功连接到远程服务器。可以通过查看IDEA界面上的提示信息来确认连接是否成功。\[2\] 3. 在IDEA中设置断点,可以在需要调试的代码行上点击鼠标左键,或者使用快捷键Ctrl + Shift + F8来设置断点。 4. 发送请求到线上服务,使其进入debug模式。可以通过浏览器或者其他工具发送请求,确保线上服务进入了debug模式。\[2\] 5. 在IDEA中进行debug调试。当线上服务接收到请求并进入debug模式后,可以在IDEA中使用调试工具来逐步执行代码,观察变量的值和程序的执行流程,以便定位和解决问题。\[3\] 需要注意的是,debug模式会影响线上请求的性能,因此在调试完毕后,最好将项目重新启动,以确保项目正常运行而没有debug的影响。\[2\] 另外,除了使用IDEA进行远程调试,还有一些其他非常好用的远程调试工具,如阿里开源的Arthas(阿尔萨斯)。这些工具可以帮助开发人员更方便地调试在线上环境中出现的特殊问题。\[3\] #### 引用[.reference_title] - *1* *3* [IDEA远程线上Debug(详细步骤图解)](https://blog.csdn.net/qq_44901285/article/details/119155617)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [使用IDEA远程Debug线上服务](https://blog.csdn.net/lv_dw962464/article/details/115320137)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sum墨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值