点击“ 程序员内点事 ”关注,选择“ 设置星标 ”
坚持学习,好文每日送达!
❝相信很多人都有这样一种感受,自己写的代码在开发、测试环境跑的稳得一笔,可一到线上就抽风,不是缺这个就是少那个反正就是一顿报错,而线上调试代码又很麻烦,让人头疼得很。不过, 阿里巴巴出了一款名叫
❞Arthas
的工具,可以在线分析诊断Java代码,让人眼前一亮。
Arthas 是什么?
Arthas(阿尔萨斯)
是阿里开源的一个Java在线分析诊断工具。
Arthas 能解决啥问题?
在日常开发上线过程中,我们多多少少都会遇到下边这些问题,苦于无法在线调试,「只能通过老鸟的经验来硬分析bug,效率上不去还总开口问别人答疑解惑,多少有些不好意思」。
这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
是否有一个全局视角来查看系统的运行状况?
有什么办法可以监控到JVM的实时运行状态?
线上代码有错误,不想重新发布?那能不能改class文件替换一下?
Arthas两种安装、启动方式
1、jar包启动
wget https://alibaba.github.io/arthas/arthas-boot.jar
java -jar arthas-boot.jar --target-ip 0.0.0.0
首先想用arthas
调试项目,服务器必须要有运行着的Java服务,demo-0.0.1-SNAPSHOT.jar
就是我启动的测试项目,启动arthas
后它会自动检测本地所有的Java服务列出来,我们只需按照序号输入想要调试的项目即可,选1
进入对应进程的arthas
交互平台
[root@iz2zehzeir87zi8q99krk1z data]# java -jar arthas-boot.jar --target-ip 172.17.72.201
[INFO] arthas-boot version: 3.1.0
[INFO] Found existing java process, please choose one and hit RETURN.
* [1]: 28679 demo-0.0.1-SNAPSHOT.jar
2、在线安装
curl -L https://alibaba.github.io/arthas/install.sh | sh
执行上面的命令会在所在的文件中生成as.sh执行文件启动arthas
./as.sh PID #进程id 指定JAVA进程id
./as.sh -h #h来获取更多参数信息
3、远程连接:
「要想使用arthas服务的 web console必须对外暴露本机ip」
java -jar arthas-boot.jar --target-ip 172.17.72.201
java -jar arthas-boot.jar --telnet-port 9999 --http-port -1
./as.sh --target-ip 0.0.0.0
./as.sh --telnet-port 9999 --http-port -1
访问arthas
控制台也有两种方法
「(1)、web console 界面」
「重点说明」:--target-ip
的ip
一定要是arthas
所在机器对外暴露的ip,「但如果用的是阿里云机器必须要使用私有ip启动arthas服务,但访问必须是公网IP」
「(2)、telnet方式」
telnet 10.0.2.5 8563
访问 http://59.110.218.9:8563/ ,进入交互平台
Arthas 命令使用
1、Dashboard 命令
查看当前系统的实时数据面板,例如:服务器thread信息、内存memory、GC回收等情况