JVM技术文档--JVM诊断调优工具Arthas--阿里巴巴开源工具--一文搞懂Arthas--快速上手--国庆开卷!!

本文主要是介绍JVM技术文档--JVM诊断调优工具Arthas--阿里巴巴开源工具--一文搞懂Arthas--快速上手--国庆开卷!!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Arthas首页  

简介 | arthas

Arthas官网文档 

Arthas首页、文档和下载 - 开源 Java 诊断工具 - OSCHINA - 中文开源技术交流社区

阿丹:

        之前聊过了一些关于JMV中的分区等等,但是有同学还是在后台问我,还有私信问我,学了这些东西,到底用在哪里?这篇文章给大家学习和介绍一下一个JVM的开源诊断工具Arthas。

Arthas是啥?

Arthas是阿里巴巴开源的Java线上诊断工具,它功能非常强大,可以解决很多线上不方便解决的问题。Arthas诊断使用的是命令行交互模式,支持JDK6+、Linux、Mac、Windows操作系统,并且命令支持使用tab键对各种信息的自动补全,使得诊断更加方便快捷。

Arthas都能诊断啥?

Arthas是由Alibaba开源的Java监控诊断工具,能够分析、诊断、定位Java应用问题,例如:

  • JVM信息、线程信息、搜索类中的方法。
  • 跟踪代码执行、观测方法的入参和返回参数等等。

Arthas最大的特点是能在不修改代码和不需要重新发布的情况下,对业务问题进行诊断,包括查看方法调用的出参入参、异常、监测方法执行耗时、类加载信息等,大大提升线上问题排查效率。

Arthas可以诊断和观测以下的一些JVM属性:

  1. 性能看板:这包括线程、CPU、内存等信息,并且会定时刷新,提供了丰富的性能诊断信息。
  2. 线程快照:根据各种条件查看线程快照,例如找出CPU占用率最高的n个线程等。
  3. JVM信息:Arthas可以输出JVM的各种信息,如GC算法、JDK版本、ClassPath等。
  4. 系统属性和环境变量:Arthas的syspropsysenv命令可以查看所有的系统变量和操作系统环境变量,也可以查看并设置某个具体的系统变量或环境变量。
  5. 类的静态属性:通过getstatic命令可以查看类的静态属性。

Arthas如何部署?

经常使用服务器的同学一定都知道一共有两种部署的方式,现在最流行也是最简单的就是直接容器化的部署,那么本篇文章我们就在docker中对这个开源工具进行容器化的部署和使用。很简单同学们只需要跟着我的步骤来就可以了。

我们的重点还是学习如何使用以及使用发现了问题我们要如何的去优化。

官方文档上给我们的方式是去直接下拉文件,然后使用//as.sh的方式来启动,或者就是通过java -jar的方式来进行启动。

从 Github Releases 页下载
https://github.com/alibaba/arthas/releases

直接使用jar包进行运行使用

用 as.sh 启动

解压后,在文件夹里有as.sh,直接用./as.sh的方式启动:

./as.sh

打印帮助信息:

./as.sh -h

用 arthas-boot 启动

或者在解压后,在文件夹里有arthas-boot.jar,直接用java -jar的方式启动:

java -jar arthas-boot.jar

他会自己进行检查本机上运行的java程序,然后按照数字选择就可以了。 

打印帮助信息:

java -jar arthas-boot.jar -h

注意:

Arthas在使用的时候要注意需要监控的容器的位置,阿丹在这里做一个说明如果是使用在本机的java -jar的方式来启动java程序的话,直接在本机使用上述方法就可以使用,但是如果需要监控的程序是在docker使用了容器化的方式来部署的话。

就需要按照下面的方式来完成对容器化的程序使用arthas监控。以及线上分析。

在docker中进行容器化的监控检测

对于要监控docker中的容器有两种方式

第一个是在构建镜像的时候就附带上arthas的jar包(针对还有没上线的程序-在之后的应急现在排查方便)缺点:在不需要使用的时候相当与在镜像中附带了冗余的jar包可能对存储内存不太友好。

第二个是在正在运行的docer容器中使用,在容器中容官网上下载对应的jar包,进入容器中使用。耗时因为要重新下载,有风险-如果内存设置不够。

下载arthas-boot的jar包--直接在目标文件夹的路径下运行即可

curl -O https://arthas.aliyun.com/arthas-boot.jar

通过打包dockerfile然后使用docker build -t的方式来做成镜像即可,在需要使用的时候都是通过docker进入对应的容器中找到镜像中的Jar包的位置然后使用java -jar来运行这个监控就可以了。

同时它也支持使用java探针的方式来启动

以 Java Agent 的方式启动

通常 Arthas 是以动态 attach 的方式来诊断应用,但从3.2.0版本起,Arthas 支持直接以 java agent 的方式启动。

比如下载全量的 arthas zip 包,解压之后以 -javaagent 的参数指定arthas-agent.jar来启动:

java -javaagent:/tmp/test/arthas-agent.jar -jar math-game.jar

默认的配置项在解压目录里的arthas.properties文件里。参考:Arthas Properties

Java Agent 机制参考:  

https://docs.oracle.com/javase/8/docs/api/java/lang/instrument/package-summary.html

还可以直接和spring-boot项目进行整合在spring-boot项目运行的时候就直接启动一个

添加如下配置

        <dependency><groupId>com.taobao.arthas</groupId><artifactId>arthas-spring-boot-starter</artifactId><version>${arthas.version}</version></dependency>

应用启动后,spring 会启动 arthas,并且 attach 自身进程。

配置属性

比如,通过配置 tunnel server 实现远程管理:

arthas.agent-id=hsehdfsfghhwertyfad
arthas.tunnel-server=ws://47.75.156.201:7777/ws

提示

默认情况下,arthas-spring-boot-starter 会禁掉stop命令。

参考:Arthas Properties

查看 Endpoint 信息

提示

需要配置 spring boot 暴露 endpoint:参考在新窗口打开

假定 endpoint 端口是 8080,则通过下面 url 可以查看:

http://localhost:8080/actuator/arthas

{"arthasConfigMap": {"agent-id": "hsehdfsfghhwertyfad","tunnel-server": "ws://47.75.156.201:7777/ws",}
}

正式开始学习和使用arthas!!!--跟上阿丹的脚步!!!

那么我直接使用jar包启动的方式来启动arthas

这个是官方的文档 

简介 | arthas

官方的文章上面已经给了很详细的教程和介绍

点击这里提供了很完美的在线学习的平台!!本文章主要是给大家安利一下这个真的很好用!! 

 线上定位好手!!

这篇关于JVM技术文档--JVM诊断调优工具Arthas--阿里巴巴开源工具--一文搞懂Arthas--快速上手--国庆开卷!!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

9个SpringBoot中的自带实用过滤器使用详解

《9个SpringBoot中的自带实用过滤器使用详解》在SpringBoot应用中,过滤器(Filter)是处理HTTP请求和响应的重要组件,SpringBoot自带了许多实用的过滤器,如字符编码,跨... 目录1. CharacterEncodingFilter - 字符编码过滤器功能和配置手动配置示例2

Spring Boot Controller处理HTTP请求体的方法

《SpringBootController处理HTTP请求体的方法》SpringBoot提供了强大的机制来处理不同Content-Type​的HTTP请求体,这主要依赖于HttpMessageCo... 目录一、核心机制:HttpMessageConverter​二、按Content-Type​处理详解1.

Spring Boot 常用注解详解与使用最佳实践建议

《SpringBoot常用注解详解与使用最佳实践建议》:本文主要介绍SpringBoot常用注解详解与使用最佳实践建议,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、核心启动注解1. @SpringBootApplication2. @EnableAutoConfi

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I

浅谈Redis Key 命名规范文档

《浅谈RedisKey命名规范文档》本文介绍了Redis键名命名规范,包括命名格式、具体规范、数据类型扩展命名、时间敏感型键名、规范总结以及实际应用示例,感兴趣的可以了解一下... 目录1. 命名格式格式模板:示例:2. 具体规范2.1 小写命名2.2 使用冒号分隔层级2.3 标识符命名3. 数据类型扩展命

一文详解如何在Vue3中封装API请求

《一文详解如何在Vue3中封装API请求》在现代前端开发中,API请求是不可避免的一部分,尤其是与后端交互时,下面我们来看看如何在Vue3项目中封装API请求,让你在实现功能时更加高效吧... 目录为什么要封装API请求1. vue 3项目结构2. 安装axIOS3. 创建API封装模块4. 封装API请求

Linux系统调试之ltrace工具使用与调试过程

《Linux系统调试之ltrace工具使用与调试过程》:本文主要介绍Linux系统调试之ltrace工具使用与调试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、ltrace 定义与作用二、ltrace 工作原理1. 劫持进程的 PLT/GOT 表2. 重定

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

Python与Java交互出现乱码的问题解决

《Python与Java交互出现乱码的问题解决》在现代软件开发中,跨语言系统的集成已经成为日常工作的一部分,特别是当Python和Java之间进行交互时,编码问题往往会成为导致数据传输错误、乱码以及难... 目录背景:为什么会出现乱码问题产生的场景解决方案:确保统一的UTF-8编码完整代码示例总结在现代软件

Java 如何创建和使用ExecutorService

《Java如何创建和使用ExecutorService》ExecutorService是Java中用来管理和执行多线程任务的一种高级工具,可以有效地管理线程的生命周期和任务的执行过程,特别是在需要处... 目录一、什么是ExecutorService?二、ExecutorService的核心功能三、如何创建