前言当遇到 JAVA 线上问题时 , 如 CPU 飙升、负载突高、内存溢出等问题 , 你需要查命令 , 查网络 , 然后 jps、jstack、jmap、jhat、jstat、hprof 等一通操作 。而除了这些 , Arthas 是一款命令行交互模式的 Java 诊断工具 , 由于是 Java 编写 , 所以可以直接下载相应 的 jar 包运行 , 它是Java 线上问题定位处理的终极利器 。
当你遇到以下类似问题而束手无策时 , Arthas可以帮助你解决:
- 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
- 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
- 遇到问题无法在线上 debug , 难道只能通过加日志再重新发布吗?
- 线上遇到某个用户的数据处理有问题 , 但线上同样无法 debug , 线下无法重现!
- 是否有一个全局视角来查看系统的运行状况?
- 有什么办法可以监控到JVM的实时运行状态?
- 怎么快速定位应用的热点 , 生成火焰图?
- 怎样直接从JVM内查找某个类的实例?
https://arthas.aliyun.com/doc/download.html#id2
上传至服务器 , 解压到某个文件文件夹(我这里文件夹叫arthas)
文章插图
切换到解压文件夹 , 启动Arthas【线上debug诊断神器-Arthas】使用命令:java -jar arthas-boot.jar启动 , 启动过程中会让你选择监控哪个项目 , 输入序号即可
文章插图
启动成功后 , 可使用官方提供的命令查看内存、线程相关信息官方命令文档:
https://arthas.aliyun.com/doc/commands.html
常用命令
文章插图
dashboard命令 可以看到 , 这里会显示出线程(按照cpu占用百分比倒排)、内存(堆空间实时情况)、GC情况等数据 。可以按Ctrl+C或者q退出
文章插图
thread命令查看所有线程信息 , 同时会列出每个线程的 CPU 使用率 , 可以看到图里 ID 为12 的线程 CPU 使用率
文章插图
thread 33命令 查看 CPU 消耗较高的 12 号线程信息 , 可以看到 CPU 使用较高的方法和行数
文章插图
thread -n 10命令查看CPU占用率前10的线程的堆栈信息
thread -b命令查看目前block线程
thread -n 5 -i 5000命令查看5s内的CPU使用率top 5线程栈
trace 包名+类名 方法名命令查看方法调用耗时
文章插图
stop命令关闭Arthas服务端
quit命令退出Arthas客户端
常保存日志将命令的结果完整保存在日志文件中 , 便于后续进行分析 , 默认情况下 , 该功能是关闭的 , 如果需要开启 , 请执行以下命令:
文章插图
推荐阅读
- Arthas线上服务器问题排查
- Android性能优化高阶:卡顿、ANR、死锁,线上如何监控?
- 如何远程debug进行调试?
- 肾病综合征护理诊断
- 吃面线上火吗?面线的营养价值有哪些?
- 冰箱|行业再现生机!因疫情冰箱线上销量又涨了
- 网站推广再掀热潮,线上营销"赛道"成热点
- 电子竞技|27岁宝妈线上求职文员,却被HR嫌弃“年纪有点大”,太悲哀
- Python线上环境如何优雅地使用日志?
- 线上 MySql 事务死锁,应该怎么排查解决?