Arthas 的进程模型

Arthas 的进程模型

Arthas 本身是一个基于 Java Agent 机制的诊断工具,它的运行分为两个关键环节,但并非 "两个独立进程":

  • 主控端(CLI) :你在终端输入命令的 Arthas 客户端(arthas-boot.jar 启动的进程),本质是一个 Java 进程,负责接收你的命令、解析并发送到目标进程。
  • 代理端(Tools) :通过 VirtualMachine.attach() 动态附加到目标 Java 进程的 Agent 代理(核心是 arthas-core.jar),它运行在目标进程的内部,而非独立进程。

简单说:

  • CLI 是独立的 "控制进程";
  • Tools/Agent 是嵌入目标进程的 "代理线程 / 模块";
  • 二者通过 Socket 通信,并非两个对等的独立进程。

2. "合并到一个 JAR 包" 的本质

Arthas 把 arthas-core.jar(代理逻辑)、arthas-cli.jar(命令行交互)、依赖库等打包到 arthas-boot.jar 中,目的是:

  • 简化部署:用户只需下载一个 JAR 就能使用所有功能;
  • 自动分发:启动时 arthas-boot.jar 会自动把内部的 Agent 包注入目标进程,无需手动拆分 JAR。

这个 "合并" 只是打包层面的整合,运行时依然是 "主控进程 + 目标进程内的 Agent 模块" 的模式。

3. 关键区别:进程 vs 线程

表格

组件 运行载体 角色
Arthas CLI 独立 Java 进程 命令输入 / 解析 / 结果展示
Arthas Agent 目标 Java 进程的内部线程 执行诊断逻辑(监控 / 反编译等)

总结

  1. Arthas 不是 "两个进程",而是一个主控进程 + 目标进程内的 Agent 模块
  2. "CLI 和 Tools 合并到一个 JAR" 是打包优化,方便使用,不改变运行时的进程模型;
  3. Agent 核心逻辑运行在目标进程内部,而非独立进程,这也是 Java Agent 的核心特性。
相关推荐
代码AI弗森5 小时前
一文理清楚“算力申请 / 成本测算 / 并发评估”
java·服务器·数据库
Old Uncle Tom5 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
小小小米粒5 小时前
Collection单列集合、Map(Key - Value)双列集合,多继承实现。
java·开发语言·windows
摇滚侠6 小时前
expdp 查看帮助
java·数据库·oracle
:1216 小时前
java基础
java·开发语言
曹牧7 小时前
Spring:@RequestMapping注解,匹配的顺序与上下文无关
java·后端·spring
daixin88487 小时前
cursor无法正常使用gpt5.5等模型解决方案
java·redis·cursor
韦禾水8 小时前
记录一次项目部署到tomcat的异常
java·tomcat
曦月合一8 小时前
树莓派安装jdk、tomcat、vnc、谷歌浏览器开机自启等环境配置
java·tomcat·树莓派
此剑之势丶愈斩愈烈8 小时前
openssl 自建证书
java