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

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

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

 线上定位好手!!

给大家分享一个很好用的idea中的插件:

arthas idea--直接在插件市场搜索就可以了。

 当我们需要语句来监控一个类的时候可以帮助我们自动的生成很方便,只需要选中对应的类名,然后鼠标右键,点击要生成的语句就可以了。

点击之后就可以直接复制粘贴对应的语句了,直接使用就可以!非常好用!!!!

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

三维模型3DTile格式轻量化的纹理压缩和质量关系分析

三维模型3DTile格式轻量化的纹理压缩和质量关系分析 在三维模型的3DTile格式轻量化处理中&#xff0c;纹理压缩是一个重要环节。但是&#xff0c;纹理压缩和模型质量之间存在明显的关系需要权衡。以下是纹理压缩和模型质量关系的详细分析&#xff1a; 1、压缩率与纹理质量&…

【UE】在游戏运行时,通过选择uasset来生成静态网格体

目录 主要流程 步骤 一、创建用于包含静态网格体的Actor蓝图 二、按钮点击事件 效果 主要流程 用户点击按钮后产生一个文件对话框&#xff0c;用户通过文件对话框选择指定的文件夹&#xff0c;我们获取到这个文件夹路径后处理成“按路径获取资产”节点所需的输入&#x…

【开发篇】二十、SpringBoot整合RocketMQ

文章目录 1、整合2、消息的生产3、消费4、发送异步消息5、补充&#xff1a;安装RocketMQ 1、整合 首先导入起步依赖&#xff0c;RocketMQ的starter不是Spring维护的&#xff0c;这一点从starter的命名可以看出来&#xff08;不是spring-boot-starter-xxx&#xff0c;而是xxx-s…

【源码】hamcrest 源码阅读 空对象模式、模板方法模式的应用

文章目录 前言1. 类图概览2. 源码阅读2.1 抽象类 BaseMatcher2.1 接口 Description提炼模式&#xff1a;空对象模式 2. 接口 Description 与 SelfDescribing 配合使用提炼模式 模板方法 后记 前言 hamcrest &#xff0c;一个被多个测试框架依赖的包。听说 hamcrest 的源码质量…

STM32 DMA从存储器发送数据到串口

1.任务描述 &#xff08;1&#xff09;ds18b20测量环境温度存储到存储器&#xff08;数组&#xff09;中。 &#xff08;2&#xff09;开启DMA将数组中的内容&#xff0c;通过DMA发送到串口 存在问题&#xff0c;ds18b20读到的数据是正常的&#xff0c;但是串口只是发送其低…

机器学习7:pytorch的逻辑回归

一、说明 逻辑回归模型是处理分类问题的最常见机器学习模型之一。二项式逻辑回归只是逻辑回归模型的一种类型。它指的是两个变量的分类&#xff0c;其中概率用于确定二元结果&#xff0c;因此“二项式”中的“bi”。结果为真或假 — 0 或 1。 二项式逻辑回归的一个例子是预测人…

Scala第十七章节

Scala第十七章节 scala总目录 文档资料下载 章节目标 了解集合的相关概念掌握Traversable集合的用法掌握随机学生序列案例 1. 集合 1.1 概述 但凡了解过编程的人都知道程序 算法 数据结构这句话, 它是由著名的瑞士计算机科学家尼古拉斯沃斯提出来的, 而他也是1984年图灵…

车险计算器微信小程序源码 带流量主功能

车险计算器微信小程序源码带流量主功能&#xff0c;可以精准的算出车险的书目&#xff0c;是一个非常实用的微信小程序源码。 简单的计算让你得知车险价值 另外也支持流量主&#xff0c;具体小编也就不多说了&#xff0c;大家自己搭建研究吧。 源码下载&#xff1a;https://d…

React xlsx(工具库) 处理表头合并

前端导出excel表格 引入xlsx插件&#xff0c;不然应该是运行不起来的 npm i xlsx xlsx中文文档 插件2 exceljs npm i exceljs exceljs中文文档 导出 例子 import { ExportExcel } from ./exportExcel/index;const columns[{title: id,dataIndex: item1,},{title: 序号,dataInd…

开环模块化多电平换流器仿真(MMC)N=6(Simulink仿真)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

RabbitMQ之Fanout(扇形) Exchange解读

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

12.1 使用键盘鼠标监控钩子

本节将介绍如何使用Windows API中的SetWindowsHookEx和RegisterHotKey函数来实现键盘鼠标的监控。这些函数可以用来设置全局钩子&#xff0c;通过对特定热键挂钩实现监控的效果&#xff0c;两者的区别在于SetWindowsHookEx函数可以对所有线程进行监控&#xff0c;包括其他进程中…

Spring Cloud Gateway2之路由详解

Spring Cloud Gateway路由 文章目录 1. 前言2. Gateway路由的基本概念3. 三种路由1. 静态路由2. 动态路由1. 利用外部存储2. API动态路由 3. 服务发现路由(自动路由)3.1. 配置方式3.2 自动路由&#xff08;服务发现&#xff09;原理核心源码GatewayDiscoveryClientAutoConfigur…

机器学习算法基础--KNN分类算法

文章目录 1.KNN算法原理介绍2.KNN分类决策原则3.KNN度量距离介绍3.1.闵可夫斯基距离3.2.曼哈顿距离3.3.欧式距离 4.KNN分类算法实现5.KNN分类算法效果6.参考文章与致谢 1.KNN算法原理介绍 KNN&#xff08;K-Nearest Neighbor&#xff09;工作原理&#xff1a; 在一个存在标签的…

Springcloud支付模块

客户端消费者80 order&#xff08;订单模块&#xff09; 微服务提供者8001 payment&#xff08;支付模块&#xff09; 订单模块可以调动支付模块 步骤&#xff1a; 1、建moudle 2、改写pom 3、写yml 4、主启类 5、业务类 1、建父工程&#xff08;创建spri…

架构师选择题--计算机网络

架构师选择题--计算机网络 22年考题21年考题20年考题19年真题2017考题 22年考题 d http:80 https:httpssl &#xff1a;443 b b pop3是邮件接收协议&#xff1a;110 SMTP是邮件发送协议&#xff1a;25 http:80 A 网络隔离&#xff1a;防火墙&#xff08;逻辑&#xff09;&…

C++(反向迭代器)

前言&#xff1a; 上一章我们介绍了适配器&#xff0c;也提了一下迭代器适配器&#xff0c;今天我们就从反向迭代器把迭代器适配器给解释一下。 既然 都叫迭代器容器了 就说名只要接口合适他可以封装实现各种容器需求包括vector list 。 目录 1.反向迭代器设计 1.1反向迭代…

Spring面试题学习: 单例Bean是单例模式吗?

单例Bean是单例模式吗 学习背景答案扩展知识单例模式Spring BeanJava Bean单例Bean 个人评价我的回答 学习背景 想换工作. 学习记录, 算是一个输出. 答案 通常来说, 单例模式是指在一个JVM中, 一个类只能构造出一个对象. 有很多方法来实现单例模式, 比如饿汉模式. 但是我们通…

【JVM】 类加载机制、类加载器、双亲委派模型详解

文章目录 前言一、类加载机制二、类加载器三、双亲委派模型总结 前言 &#x1f4d5;各位读者好, 我是小陈, 这是我的个人主页 &#x1f4d7;小陈还在持续努力学习编程, 努力通过博客输出所学知识 &#x1f4d8;如果本篇对你有帮助, 烦请点赞关注支持一波, 感激不尽 &#x1f4d…

配置文件生成器-秒杀SSM的xml整合

配置文件生成器-秒杀SSM的xml整合 思路&#xff1a; 通过简单的配置&#xff0c;直接生成对应配置文件。 maven坐标 <dependencies><!-- 配置文件生成 --><dependency><groupId>org.freemarker</groupId><artifactId>freemarker<…