arthas使用

  • arthas-packaging-4.1.8-bin.zip
  • arthas-tunnel-server-4.0.5-fatjar.jar
  • Arthas(阿尔萨斯)是阿里开源的 Java 在线诊断工具,免费、轻量、不用重启、不用改代码、不用重新部署,直接 attach 运行中的 JVM,定位线上问题神器。

一、核心特点(生产级)

  • 不用重启服务
    直接 attach 正在跑的 jar,热挂载,不影响业务。
  • 不用改代码、不加日志
    想看什么参数、返回值、异常,直接动态观测。
  • 跨平台
    Windows/Linux/macOS、Docker/K8s 都能用。
  • 轻量
    一个几百 KB 的脚本 /jar,不占资源。
  • 完全免费开源
    个人 / 公司都能用,无任何付费限制。
  • 离线可用
    不需要联网,内网环境照样跑。

二、它到底能解决什么问题?(最实用)

  1. CPU 高、load 高、接口慢
  • 看哪个方法最耗 CPU
  • 看调用栈、方法耗时
  • 直接生成火焰图定位瓶颈
  1. 死锁、线程阻塞、线程池满
  • thread 命令一键查死锁
  • 看谁在等锁、谁阻塞了业务
  1. OOM、内存泄漏
  • 看堆内存、GC 情况
  • 导出 heap dump
  • 配合 MAT 分析大对象
  1. 线上看不到入参、出参、异常
  • 不用加日志、不用重新发版:
  • watch 实时看方法入参、返回值
  • trace 看链路耗时
  • stack 看谁调用了这个方法
  1. 线上热更新、热替换(排查用)
  • 临时修改 class 验证问题
  • 不重启,快速验证修复方案
  1. 动态查看配置、Spring Bean
  • 看某个 Bean 是否存在
  • 看动态配置是否生效
  • 反编译线上运行的 class,确认代码版本
  1. 集群 / 远程诊断
  • 不登录服务器
  • 不进容器
  • 浏览器直接连线上 JVM
shell 复制代码
# 用法是多个跑业务的机器,连到同一个诊断机器
# 统一连到诊断机器,默认放通7777Websocket端口,8080为web页面端口,ip为192.168.72.128,使用时请访问http://192.168.72.128:8080
java -jar arthas-tunnel-server-4.0.5-fatjar.jar
# 实际跑业务的机器,11312为业务程序的进程号
java -jar arthas-boot.jar 11312 --tunnel-server "ws://192.168.72.128:7777/ws" --app-name my-app --agent-id my-pc-11312
相关推荐
吃饱了得干活16 小时前
Spring Cloud Gateway 微服务网关:路由、断言、过滤器
java·spring cloud
lwx5728018 小时前
探秘InnoDB:搞懂它的内存、线程、磁盘与日志刷盘策略
java·后端
Flynt19 小时前
从Spring Boot 4.0升到4.1,我在Maven和gRPC上栽了跟头
java·spring boot·后端
plainGeekDev20 小时前
Activity 间传值 → Navigation 参数
android·java·kotlin
plainGeekDev20 小时前
onActivityResult → ActivityResult API
android·java·kotlin
Sunia20 小时前
《AgentX 专栏》10-生产部署:3台2C4G云服务器把企业级Agent真正跑起来的完整方案
java·架构
ZhengEnCi21 小时前
J7A-高级Java工程师面试三道灵魂拷问-深度广度与工程素养的终极检验
java·后端
狼爷2 天前
吃透 Java Function 接口,搞定 99% 的 Stream 场景
java·函数式编程
祎雪双十Gy2 天前
从 DataX 的配置加载说起:我用 FastJson2 做了一个轻量级动态配置管理库
java·后端
小锋java12342 天前
分享一套锋哥原创的SpringBoot4+Vue3宠物领养网站系统
java