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

2023-11-23 01:10

本文主要是介绍Arthas阿里 阿尔萨斯诊断工具的学习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以下所有内容基于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最全使用姿势 - 掘金

这篇关于Arthas阿里 阿尔萨斯诊断工具的学习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/414242

相关文章

基于Python打造一个全能文本处理工具

《基于Python打造一个全能文本处理工具》:本文主要介绍一个基于Python+Tkinter开发的全功能本地化文本处理工具,它不仅具备基础的格式转换功能,更集成了中文特色处理等实用功能,有需要的... 目录1. 概述:当文本处理遇上python图形界面2. 功能全景图:六大核心模块解析3.运行效果4. 相

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

基于Python实现高效PPT转图片工具

《基于Python实现高效PPT转图片工具》在日常工作中,PPT是我们常用的演示工具,但有时候我们需要将PPT的内容提取为图片格式以便于展示或保存,所以本文将用Python实现PPT转PNG工具,希望... 目录1. 概述2. 功能使用2.1 安装依赖2.2 使用步骤2.3 代码实现2.4 GUI界面3.效

基于Python和MoviePy实现照片管理和视频合成工具

《基于Python和MoviePy实现照片管理和视频合成工具》在这篇博客中,我们将详细剖析一个基于Python的图形界面应用程序,该程序使用wxPython构建用户界面,并结合MoviePy、Pill... 目录引言项目概述代码结构分析1. 导入和依赖2. 主类:PhotoManager初始化方法:__in

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

jvm调优常用命令行工具详解

《jvm调优常用命令行工具详解》:本文主要介绍jvm调优常用命令行工具的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一 jinfo命令查看参数1.1 查看jvm参数二 jstack命令2.1 查看现场堆栈信息三 jstat 实时查看堆内存,gc情况3.1