Arthas阿里 阿尔萨斯诊断工具的学习

2023-11-20

以下所有内容基于Arthas的3.6.9版本。

一、Arthas 基础

背景:线上诊断问题比较难复现,DEBUG等 都很痛苦。

功能好处:通过JVM开放出来接口,代理功能。对JVM访问,获取JVM内存,线程,类,方法,变量等各种操作函数,并控制。

具体的使用就不详细了。Arthas文档够全的,可以直接看官方文档。简介 | arthas

二、Arthas 各类产品

1、Arthas

基础产品

2、Arthas Tunnel

相当于注册+管理中心,当有N个Arthas的时,不好管理,提供了一个管理平台,官方建议是在内网运行,或者是自己搭建一个带权限管理的平台。 我个人理解最好是在内网。

3、Arthas源码下的各类jar的作用

arthas-agent

代理类jar包。它的作用就是一个普通的java agent。 JAVA诊断类型的的产品在修改字节码等操作时都是通过Java Agent来实现的。当然Arthas也不例外。那代理可简单分为preMain和agentMain。那这个jar提供的方式就是preMain的形式,就是说在启动目前jar的时候就提前做好代理工作。这个就是产品文档中提供的demo启动示例。java -javaagent:/tmp/test/arthas-agent.jar -jar math-game.jar。 !!!注意该com.taobao.arthas.agent334中也提供了agentMain方法,说明也是可以在目标jar启动后,运行的过程中去代理。

arthas-agent-attach

attach的demo。arthas-agent.jar 是目标jar在启动时就代理的,那这个arthas-agent-attach.jar就是目标jar启动后,运行过程中代理的。它的使用方式会在arthas-spring-boot-starter.jar中提到

arthas-spring-boot-starter

我们大部分用的框架时Spring的。那把Arthas加入到SpringBoot里极大方便了我们的使用。

这个jar里干的事情:ArthasProperties读取工程内的配置数据,ArthasConfiguration类当配置信息加载完成后初始化ArthasAgent类。 ArthasAgent类就是arthas-agent-attach.jar包中的。它的作用就是将SpringBoot工程启动后,使Arthas这个工具attach自身,并监听端口,这个端口可自行配置,具体看文档,甚至可以自身的信息Socket到Arthas Tunnel Server上。让用户可以远程诊断这个SpringBoot工程。

arthas-vmtool

它是关于JVM的操作包,通过自己写的C语言的程序,然后VmTool类去调用C语言写好的本地方法,比如: GC,获取某个class在jvm中当前所有存活实例,统计某个class在jvm中当前所有存活实例的总占用内存,获取某个实例的占用内存等等。

arthas-boot

命令行界面。它启动后会执行jps命令,查看JVM的进程。然后供用户选择。代理类还是用的arthas-agent.jar包

arthas-client

你启动了arthas-boot.jar后,首选会看到正在运行的JVM进程,然后让你选择进程,选择后出现的命令行界面,还有后续的交互,都是这jar负责的。还拷贝了Apache net 工具包的代码进行,没有选择以jar的形式加载这个工具包。

arthas-common

公共的工具包

arthas-core

这个就不多说了,核心。attch的操作,行命令的实现等等都是再这里完成的。

arthas-memorycomplier

 动态的编译java文件的工具包,StringSource定义了从源文件加载成String串,MemoryByteCode定义了从源文件加载成字节流。然后动态编译器DynamicCompiler将String串,或者字节流,编译为字节码。

arthas-packaging

将arthas一系列产品打成压缩文件的工具包

arthas-site

VUE写的文档展示站点

arthas-spy

arthas-spy.jar里面只包含Spy类,目的是为了将Spy类使用BootstrapClassLoader来加载,从而使目标进程的java应用可以访问Spy类。通过ASM修改字节码,可以将Spy类的方法ON_BEFORE_METHOD, ON_RETURN_METHOD等编织到目标类里面。

arthas-tunnel-client

与arthas-tunnel-server通信的工具包。

arthas-tunnel-common

arthas-tunnel-client和arthas-tunnel-server公共的包。就是一些通信常量

arthas-tunnel-server

官网介绍的挺详细的 Arthas Tunnel | arthas

推荐一篇文章:  Arthas最全使用姿势 - 掘金

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Arthas阿里 阿尔萨斯诊断工具的学习 的相关文章

  • 分布式时序相似查询初探

    时序数据 即随时间变化的数据 在人们的日常生活中无处不在 过去的近十年来 随着电子监控和智能穿戴等设备的普及 更是产生了海量的时序数据 例如 经过多年的发展 火力发电行业的数字化程度已经达到了很高的水平 以一台60万千瓦的中型火电机组为例
  • c#复习题(简答题:基础+面向对象)

    1 简答题 填写程序 要求如下 输入三角形三条边 先判断是否可以构成三角形 如果可以 则求三角形的周长和面积 否则报错 提示 输入的三个数构成三角形三边的条件 每条边长均大于0 并且任意两边之和大于第三边 代码编写 static void
  • 从zookeeper官方文档系统学习zookeeper

    从zookeeper官方文档系统学习zookeeper 1 zookeeper 2 zookeeper 文档 3 zookeeper 单机版 3 1 配置 3 2 启动 3 3 验证 4 zookeeper 集群版 4 1 配置 4 2 启
  • centos7 Jumpserver堡垒机部署以及使用详情

    一 跳板机 堡垒机的概念 1 跳板机 跳板机就是一台服务器 运维人员在使用管理服务器的时候 必须先连接上跳板机 然后才能去操控内网中的服务器 才能登录到目标设备上进行维护和操作 跳板机的缺点 仅仅实现服务器登录安全 但是没有实现对于运维人员
  • ChatGPT-Sorry, you have been blocked 解决办法

    使用无痕模式登录 已谷歌浏览器举例 右上点打开性的无痕模式 再访问地址 如下 可以继续登录了

随机推荐

  • Hadoop生态概述及常见报错

    Hadoop Hadoop是一个开源框架来存储和处理大型数据在分布式环境中 它包含两个模块 一个是MapReduce 另外一个是Hadoop分布式文件系统 HDFS MapReduce 它是一种并行编程模型在大型集群普通硬件可用于处理大型结
  • 亲测有效win10系统QQ音乐无法安装

    本人使用win10专业版时 因为一些原因 多次下载qq音乐都无法进入安装界面 找了很多原因都无法解决 最后在网上找到好像是因为火绒的原因 于是关闭火绒 再次尝试安装 遂成功 实在不行可以卸载火绒安全后重启电脑 再从官网重新下载QQ音乐安装包
  • 数据预处理-独热编码(One-Hot)

    1 部分特征如人的性别有男女 国家有中国 美国 法国等 并不是连续的 而是离散的 无序的 通常我们需要对其进行特征数字化 2 假如某个样本 某个人 他的特征是这样的 男 中国 乒乓球 我们可以用 0 0 4 来表示 但是这样的特征处理并不能
  • BeautifulSoup基本用法总结

    BeautifulSoup是Python的一个库 最主要的功能就是从网页爬取我们需要的数据 BeautifulSoup将html解析为对象进行处理 全部页面转变为字典或者数组 相对于正则表达式的方式 可以大大简化处理过程 0x01 安装 建
  • Leetcode 106. 从中序与后序遍历序列构造二叉树

    文章目录 题目 代码 9 18 首刷自解 题目 Leetcode 106 从中序与后序遍历序列构造二叉树 代码 9 18 首刷自解 class Solution public unordered map
  • UE4文字显示乱码“字字字字字字字字”的解决办法

    键盘win R 搜索fonts 2 滑到最底下右键复制 宋体常规简体字 3 复制到ue4项目的字体文件夹中 如下 注意在外部文件处复制 4 回到项目界面 此时右下角会有个弹窗提示是否确认导入 点击导入 然后会弹一个 字体样式导入选项 弹框
  • openGauss学习笔记-63 openGauss 数据库管理-资源池化架构

    文章目录 openGauss学习笔记 63 openGauss 数据库管理 资源池化架构 openGauss学习笔记 63 openGauss 数据库管理 资源池化架构 本文档主要介绍资源池化架构下的一些最佳实践和使用注意事项 用于支撑对相
  • go Cobra命令行工具入门

    简介 Github https github com spf13 cobra Star 26 5K Cobra是一个用Go语言实现的命令行工具 并且现在正在被很多项目使用 例如 Kubernetes Hugo和Github CLI等 通过使
  • Failed to set locale, defaulting to C.UTF-8解决方法

    CentOS 8Linux系统提示 Failed to set locale defaulting to C UTF 8 这是由于没有配置正确的语言环境导致的 Linux百科 使用root账户登录你的CentOS操作系统 然后执行两条命令
  • 现阶段计算机网络技术专业人才培养的发展对策

    确立具有高职特色的人才培养目标 在市场经济的条件下 人才培养首先要适应市场需求 以市场行业的需求为导 向制定人才培养目标 学校人才培养是否能满足社会需求 可以通过学生在对口行 业及相关领域的就业情况来衡量 高职教育培养高技能应用型人才 与研
  • Objective-C中的封装、继承、多态、分类

    封装 封装最好理解了 封装是面向对象的特征之一 是对象和类概念的主要特性 封装 也就是把客观事物封装成抽象的类 并且类可以把自己的数据和方法只让可信的类或者对象操作 对不可信的进行信息隐藏 继承 面向对象编程 OOP 语言的一个主要功能就是
  • 测试工具73款

    我们将本文的软件测试工具分为4类 1 Web应用测试工具 2 网站安全测试工具 3 跨浏览器测试工具 4 移动应用测试工具 注 工具排名没有任何意义 1 Web应用测试工具 我们列出了一些在Web应用程序上执行性能 负载和压力测试的关键工具
  • 开源项目MiniWord .NET Word 操作由Word模板和数据简单、快速生成文件

    MiniWord NET Word 介绍 MiniWord NET Word模板引擎 藉由Word模板和数据简单 快速生成文件 image Getting Started 安装 nuget link https www nuget org
  • ubuntu18.04命令安装ros2

    ROS2官方文档 本教程为apt get命令安装方式 官网教程有点问题 借鉴一下大佬的安装方式 文章目录 1 安装ROS2 1 1 安装秘钥相关指令 1 2 授权秘钥 1 3 添加ROS2软件源 1 4 安装 2 设置环境 可选但是推荐 2
  • vue路由器学习(个人学习笔记四)

    目录 友情提醒 第一章 路由简介 1 1 什么是路由 1 2 安装路由插件 第二章 自定义路由器 2 1 创建路由器文件index js文件 2 2 index js文件中配置路由信息 第三章 使用路由器 3 1 在main js文件中将路
  • 基于Item的协同过滤算法实践(最简单的在线电影推荐系统)

    上一篇文章 基于用户的协同过滤算法实践 中 基于用户的相似度生成推荐列表 本文将基于Item的相似度阐述 1 相似度 基于物品的协同过滤算法 简称ItemCF 给用户推荐那些和他们之前喜欢的物品相似的物品 不过ItemCF不是利用物品的内容
  • 用户权限数据转换为用户组列表(3/3) - Excel PY公式

    最近Excel圈里的大事情就是微软把PY塞进了Excel单元格 可以作为公式使用 轻松用PY做数据分析 系好安全带 老司机带你玩一把 实例需求 如下是AD用户的列表 每个用户拥有该应用程序的只读或读写权限 现在需要创建新的AD用户组 并根据
  • Source Insight4.0的安装以及配置

    安装source insight4 工具的动机 1 公司需求 2 source insight4 0工具是集开发快速以及界面美观和方便等多种优点于一个软件的编辑器 1 需要准备资料 source insight4 0的安装包 以及安装的过程
  • iOS内存详解

    堆栈 iOS内存条中有一部分是只读的 有一部分是可读可写的 我们操作的是可读可写部分 那么在这块内存当中 我们怎么划分堆和栈呢 我们可以限定死堆栈的内存空间 但是这样显然是不好的 那么可以使用相对弹性的空间 一个从上往下扩展 一个从下往上扩
  • Arthas阿里 阿尔萨斯诊断工具的学习

    以下所有内容基于Arthas的3 6 9版本 一 Arthas 基础 背景 线上诊断问题比较难复现 DEBUG等 都很痛苦 功能好处 通过JVM开放出来接口 代理功能 对JVM访问 获取JVM内存 线程 类 方法 变量等各种操作函数 并控制