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按照24个实用大方向精选的上千种工具库汇总整理

《Python按照24个实用大方向精选的上千种工具库汇总整理》本文整理了Python生态中近千个库,涵盖数据处理、图像处理、网络开发、Web框架、人工智能、科学计算、GUI工具、测试框架、环境管理等多... 目录1、数据处理文本处理特殊文本处理html/XML 解析文件处理配置文件处理文档相关日志管理日期和

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

基于Python实现简易视频剪辑工具

《基于Python实现简易视频剪辑工具》这篇文章主要为大家详细介绍了如何用Python打造一个功能完备的简易视频剪辑工具,包括视频文件导入与格式转换,基础剪辑操作,音频处理等功能,感兴趣的小伙伴可以了... 目录一、技术选型与环境搭建二、核心功能模块实现1. 视频基础操作2. 音频处理3. 特效与转场三、高

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os