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

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

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

 线上定位好手!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/150447.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

Java多线程篇(7)——AQS之共享锁(Semaphore、CountDownLatch)

文章目录 1、Semaphore1.1、acquire1.2、release 2、CountDownLatch2.1、await2.2、countDown 1、Semaphore 1.1、acquire Semaphore.acquire public void acquire() throws InterruptedException {sync.acquireSharedInterruptibly(1);}AbstractQueuedSynchronizer.acquireSh…

pytorch算力与有效性分析

pytorch Windows中安装深度学习环境参考文档机器环境说明3080机器 Windows11qt_env 满足遥感CS软件分割、目标检测、变化检测的需要gtrs 主要是为了满足遥感监测管理平台&#xff08;BS&#xff09;系统使用的&#xff0c;无深度学习环境内容swin_env 与 qt_env 基本一致od 用于…

RabbitMQ之Direct(直连)Exchange解读

目录 基本介绍 使用场景 springboot代码演示 演示架构 工程概述 RabbitConfig配置类&#xff1a;创建队列及交换机并进行绑定 MessageService业务类&#xff1a;发送消息及接收消息 主启动类RabbitMq01Application&#xff1a;实现ApplicationRunner接口 基本介绍 在r…

【MySql】mysql之进阶查询语句

目录 一、常用查询 1、order by按关键字排序❤ 1.1 升序排序 1.2 降序排序 1.3 结合where进项条件过滤再排序 1.4 多字段排序 2、and和or判断 2.1 and和or的使用 2.2 嵌套、多条件使用 3、distinct 查询不重复记录 4、group by 对结果进行分组 5、limit限制结果…

K8S:配置资源管理 Secret和configMap

文章目录 一.Secret1.Secret概念2.Secret的类型①kubernetes.io/service-account-token②opaque③kubernetes.io/dockerconfigjson④kubernetes.io/tls 3.secret的三种参数①tls②docker-registry③generic 4.Pod 的3种方式来使用secret5.Secret创建及案例&#xff08;1&#x…

算法题:柠檬水找零

这道题就是纯贪心算法题&#xff0c;遍历每个顾客&#xff0c;先把钱收了&#xff0c;如果是10块钱就判断手里头有没有5元用于找零&#xff1b;如果是20块钱&#xff0c;先判断是不是有10元5元&#xff0c;如果没有就再判断是否有3个5元。没有的话就直接返回 False。(完整题目附…

模型压缩部署概述

模型压缩部署概述 一&#xff0c;模型在线部署 1.1&#xff0c;深度学习项目开发流程 1.2&#xff0c;模型训练和推理的不同 二&#xff0c;手机端CPU推理框架的优化 三&#xff0c;不同硬件平台量化方式总结 参考资料 一&#xff0c;模型在线部署 深度学习和计算机视觉…

excel中将一个sheet表根据条件分成多个sheet表

有如下excel表&#xff0c;要求&#xff1a;按月份将每月的情况放在一个sheet中。 目测有6个月&#xff0c;就应该有6个sheet&#xff0c;每个sheet中体现本月的情况。 一、首先增加一个辅助列&#xff0c;月份&#xff0c;使用month函数即可。 填充此列所有。然后复制【月份】…

QT内存管理

Qt的半自动化的内存管理 &#xff08;1&#xff09;QObject及其派生类的对象&#xff0c;如果其parent非0&#xff0c;那么其parent析构时会析构该对象。 &#xff08;2&#xff09;QWidget及其派生类的对象&#xff0c;可以设置 Qt::WA_DeleteOnClose 标志位(当close时会析构…

代码随想录算法训练营第23期day14|二叉树层序遍历、226.翻转二叉树、101. 对称二叉树

目录 一、二叉树层序遍历 非递归法 递归法 相关题目&#xff08;10题&#xff09; 二、&#xff08;leetcode 226&#xff09;翻转二叉树 递归法 层序遍历 深度优先遍历 1&#xff09;非统一写法——前序遍历 2&#xff09; 统一写法——前序遍历 三、&#xff08;le…

C++设计模式-享元(Flyweight)

目录 C设计模式-享元&#xff08;Flyweight&#xff09; 一、意图 二、适用性 三、结构 四、参与者 五、代码 C设计模式-享元&#xff08;Flyweight&#xff09; 一、意图 运用共享技术有效地支持大量细粒度的对象。 二、适用性 一个应用程序使用了大量的对象。完全由…

十一工具箱流量主小程序源码

无授权&#xff0c;去过滤机制版本 看到网上发布的都是要授权的 朋友叫我把他去授权&#xff0c;能用就行 就把过滤去了 这样就不用授权 可以免费使用 白嫖党专属 一切接口可用&#xff0c;无需担心不能用 授权者不关站一直可以用 源码下载&#xff1a;https://download.csdn.…

抄写Linux源码(Day19:读取硬盘前的准备工作有哪些?)

回忆我们需要做的事情&#xff1a; 为了支持 shell 程序的执行&#xff0c;我们需要提供&#xff1a; 1.缺页中断(不理解为什么要这个东西&#xff0c;只是闪客说需要&#xff0c;后边再说) 2.硬盘驱动、文件系统 (shell程序一开始是存放在磁盘里的&#xff0c;所以需要这两个东…

在WIN10平台上体验Microsoft古老的Quick C 1.0编程

前言&#xff1a; 90年代初&#xff0c;微软出了Quick系统对抗Borland Turbo系列&#xff0c;其中包括 QuickBasic, QuickPascal和Quick C。1991年&#xff0c;Quick C for Windows 1.0发布&#xff0c;后来它被Visual C取代。我自己觉得微软成就在那个winstub.exe桩上&#xf…

Connect to 127.0.0.1:1080 [/127.0.0.1] failed: Connection refused: connect

报错信息 A problem occurred configuring root project CourseSelection. > Could not resolve all artifacts for configuration :classpath.> Could not resolve com.android.tools.build:gradle:3.6.1.Required by:project :> Could not resolve com.android.tool…

【数据库——MySQL】(14)过程式对象程序设计——游标、触发器

目录 1. 游标1.1 声明游标1.2 打开游标1.3 读取游标1.4 关闭游标1.5 游标示例 2. 触发器2.1 创建触发器2.2 修改触发器2.3 删除触发器2.4 触发器类型2.5 触发器示例 参考书籍 1. 游标 游标一般和存储过程一起配合使用。 1.1 声明游标 要使用游标&#xff0c;需要用到 DECLAR…

C++:继承

本文主要从 继承的概念及定义 、基类和派生类对象赋值转换、继承中的作用域、派生类的默认成员函数、继承与友元、继承与静态成员 、复杂的菱形继承及菱形虚拟继承 、继承的总结和反思 方面介绍继承。 目录 一、继承的概念及定义 1.继承的概念 2.继承定义 1.定义格式 2.继…

抄写Linux源码(Day17:你的键盘是什么时候生效的?)

回忆我们需要做的事情&#xff1a; 为了支持 shell 程序的执行&#xff0c;我们需要提供&#xff1a; 1.缺页中断(不理解为什么要这个东西&#xff0c;只是闪客说需要&#xff0c;后边再说) 2.硬盘驱动、文件系统 (shell程序一开始是存放在磁盘里的&#xff0c;所以需要这两个东…

用IDEA操作数据库--MySQL

IDEA集成了DataGrip的操作数据库的功能 就可以省略我们下载SQLyog/Navicat/DataGrip这些图形化操作工具了 以下是IDEA的使用 输入数据库的用户和密码

软件测试|Python自动化测试实现的思路

Python自动化测试常用于Web应用、移动应用、桌面应用等的测试 Python自动化实现思路通常分为以下几步&#xff1a; 1. 确定自动化测试的范围和目标&#xff1a; 首先需要明确需要进行自动化测试的范围和目标&#xff0c;包括测试场景、测试用例、测试数据等。 2. 选择自动化…