0

0

如何在Java中使用Arthas诊断工具环境_线上Java问题排查

P粉602998670

P粉602998670

发布时间:2026-03-08 09:51:46

|

761人浏览过

|

来源于php中文网

原创

如何在java中使用arthas诊断工具环境_线上java问题排查

Arthas 启动失败:找不到 java 或提示 NoClassDefFoundError: sun/misc/Signal

Arthas 依赖目标 JVM 的运行时类,不是所有 JDK 版本都默认包含 sun.misc.Signal(尤其 JDK 11+ 默认移除了该类)。启动报这个错,基本是 JDK 版本不兼容或 Arthas 自身版本太老。

  • java -version 确认线上 JDK 是 OpenJDK 还是 Oracle JDK,以及具体版本(如 17.0.2
  • Arthas 3.6.0+ 才完整支持 JDK 17;JDK 11~16 推荐用 3.5.5;JDK 8 必须用 3.4.x 或更早
  • 别直接下载官网首页的“最新版”——它可能已放弃对旧 JDK 的兼容;去 GitHub Releases 按 JDK 版本选 tag
  • 启动命令别写成 ./as.sh pid 就完事,加 -v 看详细日志:./as.sh -v -p 12345

watch 命令返回空或超时:方法没被命中?参数没抓到?

watch 不是万能监听器,它依赖 JVM 的字节码增强(bytecode retransformation),而很多框架(Spring AOP、Lombok、CGLIB 代理)会让实际执行的方法和你写的源码不一致。

  • 先用 sc -d *YourService* 确认类是否已被加载,再用 sm *YourService* methodName 看方法签名是否匹配(注意泛型擦除后是 Object 还是 String
  • 如果方法在代理类里(比如 com.example.YourService$$EnhancerBySpringCGLIB$$abc123),就得 watch 那个代理类,而不是原始类名
  • 避免用通配符过度匹配:watch com.example.* * * -n 5 可能触发大量增强,导致应用卡顿甚至 OOM
  • -x 3 展开深度,否则嵌套对象只显示 toString() 结果,看不出真实值

线上不能连公网,怎么离线部署 Arthas?

Arthas 启动时默认会检查更新、下载附加组件(如 arthas-spring-boot-starter),但内网环境没外网权限就会卡住或失败。

Clipfly
Clipfly

一站式AI视频生成和编辑平台,提供多种AI视频处理、AI图像处理工具。

下载
  • 下载完整离线包:arthas-bin.zip(不是 arthas-boot.jar),解压后所有脚本和 jar 都在本地
  • 启动前设环境变量禁用远程行为:export ARTHAS_DISABLE_UPDATE_CHECK=true
  • ./as.sh --no-update-notifier -p 12345 强制跳过检查
  • 如果目标进程开了 SecurityManager,需确认 RuntimePermission("accessDeclaredMembers")ReflectPermission("suppressAccessChecks") 已授权,否则 ognlwatch 全部失效

thread -n 5 显示的线程全是 WAITING,但 CPU 却飙高

CPU 高 ≠ 线程在 RUNNABLE,Java 线程状态是 JVM 层面的视图,而 CPU 使用可能来自 JNI 调用、GC、锁竞争、或 native 代码(比如 Netty 的 epoll_wait、Log4j2 的异步日志队列)。

立即学习Java免费学习笔记(深入)”;

  • 先用 dashboard 看整体 GC 频率和耗时,vmtool --action getInstances --className java.lang.Thread --limit 10 查原生线程 ID(nid)
  • 配合系统命令定位:top -Hp <pid></pid> 找出高 CPU 的线程,再用 printf "%x\n" <tid></tid> 转为十六进制,去 thread 输出里搜 nid
  • 如果高 CPU 线程对应的是 Unsafe.parkepollWait,大概率是 I/O 等待或锁争用,不是 Java 方法本身耗 CPU
  • 别迷信 thread -n,它只看 Java 栈;真要深挖得结合 async-profilerperf 抓 native stack

Arthas 是把好刀,但它的输出只是线索,不是结论。最常被忽略的是:它看到的永远是“快照”,而问题往往藏在两次快照之间的状态漂移里——比如一个被反复创建又丢弃的临时对象,在 watch 里一闪而过,但在 heapdump 里能看清引用链。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

154

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

88

2026.01.26

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

970

2023.08.02

printf用法大全
printf用法大全

php中文网为大家提供printf用法大全,以及其他printf函数的相关文章、相关下载资源以及各种相关课程,供大家免费下载体验。

76

2023.06.20

fprintf和printf的区别
fprintf和printf的区别

fprintf和printf的区别在于输出的目标不同,printf输出到标准输出流,而fprintf输出到指定的文件流。根据需要选择合适的函数来进行输出操作。更多关于fprintf和printf的相关文章详情请看本专题下面的文章。php中文网欢迎大家前来学习。

303

2023.11.28

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

435

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

601

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

763

2023.08.10

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

44

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.2万人学习

C# 教程
C# 教程

共94课时 | 10.8万人学习

Java 教程
Java 教程

共578课时 | 78.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号