消失的Java堆栈

本文介绍了线上遇到的一个查询卖家订单接口抛出NPE异常,但日志中未显示堆栈的问题。通过测试发现,由于Java的JIT编译机制,热点代码会被编译为Native Code,导致堆栈丢失。利用Arthas的watch命令,可以在运行时观察到堆栈,其通过字节码增强技术避免了JIT编译,从而恢复堆栈信息。此外,文章还提及了Arthas的tt命令用于记录和查看方法执行的上下文。
摘要由CSDN通过智能技术生成

arthas原理系列文章:

  1. OGNL语法规范
  2. 消失的堆栈

  3. Arthas原理系列(一):利用JVM的attach机制实现一个极简的watch命令

  4. Arthas原理系列(二):总体架构和项目入口

  5. Arthas原理系列(三):服务端启动流程

  6. Arthas原理系列(四):字节码插装让一切变得有可能

​​​​​​​前言

这周的某天突然爆出线上查询卖家订单异常的报警,因为这个接口量比较大,赶紧排查马上介入看了下,找到日志后发现这个接口的实现抛了NPE,但是在日志里看不到堆栈。因为封网的时间已经很长了,应该不是发布导致的。但无论如何,要先定位到抛NPE的地方,才能知道是哪里出了问题

消失的堆栈

我们用下面的代码来做一次测试

public class DemoApplication {

 public stati
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值