使用Arthas排查线上报错

下载Arthas

# 下载:
wget https://arthas.aliyun.com/arthas-boot.jar
# 启动:
java -jar arthas-boot.jar

启动

启动完Arthas后他会自动检测宿主机正在运行的Java程序,输入数字可连接对应程序

注意:打成镜像部署在docker中的Java程序通过jar的形式直接启动他检测不到,可以通过docker将他打成镜像到docker启动(经过测试,用镜像启动还需要把他和运行程序建立在同一个网络下才可以检测到,因为docker具有隔离性,每一个容器都是一个命名空间,这边暂未研究出来)

所以需要将程序以jar包的形式启动才可以使用Arthas检测

排查报错

找到报错方法,使用Arthas来监听入参,出参,以及异常信息

通过报错日志来找到对应的类以及方法

watch ${类路径} ${方法名} "{params, returnObj, throwExp}" -x 5

 watch 代表监听方法

params 代表监听入参

returnObj 代表监听出参

throwExp 代表监听异常

-x 5 代表5层深度

监听完后再次请求

查看到入参

这种是正常调用

 在线上没有日志的情况下,可以单独更新单独类(例如添加日志)

在本地修改完代码后,编译为class文件,上传到服务器

 retransform  /${路径}/${类名}.class

 retransform 动态编译类

查看反编译后的类(是否更新)

retransform --deleteAll

删除所有编译过的类 

优化效率

查看接口耗时

trace ${类全路径} ${方法}

 

优化耗时较长的 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值