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属性:
- 性能看板:这包括线程、CPU、内存等信息,并且会定时刷新,提供了丰富的性能诊断信息。
- 线程快照:根据各种条件查看线程快照,例如找出CPU占用率最高的n个线程等。
- JVM信息:Arthas可以输出JVM的各种信息,如GC算法、JDK版本、ClassPath等。
- 系统属性和环境变量:Arthas的
sysprop
和sysenv
命令可以查看所有的系统变量和操作系统环境变量,也可以查看并设置某个具体的系统变量或环境变量。 - 类的静态属性:通过
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--直接在插件市场搜索就可以了。
当我们需要语句来监控一个类的时候可以帮助我们自动的生成很方便,只需要选中对应的类名,然后鼠标右键,点击要生成的语句就可以了。
点击之后就可以直接复制粘贴对应的语句了,直接使用就可以!非常好用!!!!