记得之前写过一篇Arthas使用教程 ,通过使用Arthas我们既可以实现线上调试,还可以实现热修复。最近逛了下Arthas的官网,发现它已经支持直接集成到SpringBoot应用中去,并且还出了专用的IDEA插件。今天我们再来体验下它,看看它的功能是不是更强大了!

SpringBoot实战电商项目mall(50k+star)地址:github.com/macrozheng/…

Arthas简介

Arthas是Alibaba开源的Java诊断利器,深受开发者喜爱,目前在Github上已有29K+Star。它采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。

ArthasTunnel

为了演示一个更加真实的线上环境,接下来我们将对Docker容器中的SpringBoot应用进行诊断。我们将使用ArthasTunnel来实现,ArthasTunnel相当于一个Web控制台,使用它我们无需进入应用容器即可对应用进行诊断,非常方便。

  • 首先我们需要下载ArthasTunnel的安装包,下载地址:github.com/alibaba/art…

  • 由于官方只提供了JAR包,如果你想通过Docker方式启动的话,可以自行打包Docker镜像,打包使用的Dockerfile脚本如下:
# 该镜像需要依赖的基础镜像
FROM java:8
# 将当前目录下的jar包复制到docker容器的/目录下
ADD arthas-tunnel-server.jar /arthas-tunnel-server.jar
# 声明服务运行的端口
EXPOSE 8080 7777
# 指定docker容器启动时运行jar包
ENTRYPOINT ["java", "-jar","/arthas-tunnel-server.jar"]
# 指定维护者的名字
MAINTAINER macro
  • 这里再提供一个一键打包运行ArthasTunnel容器的执行脚本run.sh,脚本内容如下;
#!/usr/bin/env bash
# 定义应用组名
group_name='mall-tiny'
# 定义应用名称
app_name='arthas-tunnel-server'
# 定义应用版本
app_version='1.0-SNAPSHOT'
echo '----copy jar----'
docker stop ${app_name}
echo '----stop container----'
docker rm ${app_name}
echo '----rm container----'
docker rmi ${group_name}/${app_name}:${app_version}
echo '----rm image----'
# 打包编译docker镜像
docker build -t ${group_name}/${app_name}:${app_version} .
echo '----build image----'
docker run -p 8080:8080 -p 7777:7777 --name ${app_name} \
-e TZ="Asia/Shanghai" \
-v /etc/localtime:/etc/localtime \
-v /mydata/app/${app_name}/logs:/var/logs \
-d ${group_name}/${app_name}:${app_version}
echo '----start container----'
  • 接下来吧ArthasTunnel的JAR包、Dockerfile文件、执行脚本run.sh上传到Linux服务器上,然后使用./run.sh命令运行即可;

  • 运行成功后,可以直接访问ArthasTunnel的Web控制台,访问地址:http://192.168.3.105:8080

SpringBoot集成

在SpringBoot应用中直接集成Arthas并使用,无疑是最方便的,接下来我们将采用此种方法。

  • 首先在项目的pom.xml中添加如下依赖,可以对比下Arthas使用教程 中的使用方法,直接集成确实简单不少;
<!--集成Java诊断利器Arthas-->
<dependency><groupId>com.taobao.arthas</groupId><artifactId>arthas-spring-boot-starter</artifactId><version>3.6.1</version>
</dependency>
  • 然后修改配置文件application.yml,记住这个agent-idArthasTunnel连接需要使用,由于我们将会把应用容器通过--link的方式连接到ArthasTunnel容器,这里的tunnel-server按下面进行配置;
management:endpoints:web:exposure:# 暴露端点`/actuator/arthas`include: 'arthas'
arthas:agent-id: mall-tiny-arthastunnel-server: ws://arthas-tunnel-server:7777/ws
  • 接下来通过之前的Dockerfile和run.sh打包应用,run.sh与之前对比,只多了一行通过--link连接到ArthasTunnel容器的命令;

  • 打包使用的Dockerfile和运行脚本run.sh都已经包含在示例代码中了,结构如下;

  • 接下来在ArthasTunnel的Web控制台中输入AgentIdmall-tiny-arthas,并点击Connect按钮即可开始诊断Java应用了;

  • 比如通过dashboard命令来显示当前系统的实时数据面板,包括线程信息、JVM内存信息及JVM运行时参数;

  • 再比如说使用thread命令查看当前线程信息,查看线程的堆栈,可以找出当前最占CPU的线程;

  • 当然Arthas的功能非常强大,远不止这些,支持动态修改日志和热更新等,具体可以参考Arthas使用教程 。

IDEA插件

由于Arthas的功能很强大,需要记住的命令很多,有时候实在记不住,于是有了这款IDEA插件,该插件主要用于帮助生成Arthas命令。

  • 直接在IDEA的插件市场搜索arthas即可找到该插件,然后点击安装即可;

  • 安装完成后我们来聊聊如何使用,比如当我们觉得线上代码和预期不一致,可以使用jad命令反编译下看看,直接选择类,右键选择Arthas命令然后选择Jad反编译;

  • 此时将会直接把命令拷贝到剪切板,然后到ArthasTunnel右键粘贴即可使用,比手打命令简单多了吧!

  • 如果你想观察方法执行过程中的参数和返回值,可以使用watch命令,选择需要观察的方法右键选择即可;

  • 这里观察下Controller中的方法的执行过程;

  • 我们还可单独修改某个类的日志级别,选中类名后右键选择logger命令;

  • 先拷贝下logger sc命令查看下当前类的日志级别为INFO

  • 拷贝下ClassLoader的Hash值,这里由于在Linux中Ctrl+C键有冲突,使用Ctrl+Insert组合来拷贝;

  • 接下来输入ClassLoader的Hash值,修改下日志级别,然后拷贝修改日志级别的命令;

  • 执行完后再查看下日志级别,已经被改为了DEBUG级别

总结

今天体验了一把新版的Arthas,搭配ArthasTunnel和IDEA插件使用,确实非常方便!并且它还能和SpringBoot无缝集成,确实非常给力,更多Arthas的使用可以参考Arthas使用教程 。

参考资料

  • 项目官网:github.com/alibaba/art…
  • Arthas官方文档:arthas.aliyun.com/doc/index.h…
  • IDEA插件使用文档:www.yuque.com/arthas-idea…

项目源码地址

github.com/macrozheng/…

阿里开源的诊断神器(Arthas)自带IDEA插件真香!相关推荐

  1. 阿里开源java调试_阿里开源java诊断工具Arthas

    快速安装 使用as.sh Arthas 支持在 Linux/Unix/Mac 等平台上一键安装,请复制以下内容,并粘贴到命令行中,敲 回车 执行即可: curl -L https://alibaba. ...

  2. 快速了解 Java 线上问题快速诊断神器 Arthas

    快速了解 Java 线上问题快速诊断神器 Arthas 1.什么是 Arthas Arthas 是 Alibaba开源的一款 Java 诊断工具,能够查看 Java 应用的线程状态.JVM 信息等,支 ...

  3. 开源应用诊断利器 Arthas GitHub Star 突破两万

    一.Arthas Star突破2万啦 https://github.com/alibaba/arthas 随着微服务的流行,应用更加轻量和开发效率不断提升,但是带来的困境是线上问题排查越来越复杂困难. ...

  4. java诊断神器 arthas(阿尔萨斯)

    java诊断神器 arthas(阿尔萨斯) 官网地址:https://arthas.aliyun.com/doc/en/index.html 1.快速开始 1.1.windows版本安装 # 命令行输 ...

  5. 阿里开源内核诊断工具:diagnose-tools

    小编说: 今天为大家介绍一款实用工具--阿里开源内核诊断工具diagnose-tools.diagnose-tools是由阿里巴巴开发的linux内核诊断工具,用于linux性能分析,特别是大规模集群 ...

  6. 阿里开源数据同步神器DataX异构数据源间数据同步同步MySQL与HDFS相互实战

    Datax 实战使用 继上一篇 阿里开源数据同步神器DataX异构数据源间数据同步基础介绍与快速入门之后的实战篇 1.MySQL-To-HDFS 环境 & 准备说明: 描述: 为了快速搭建测试 ...

  7. curl循环监控_阿里巴巴开源性能监控神器Arthas

    线上经常遇到MQ消费速度忽高忽低,但是线下测试却没有问题.那会是哪一个问题引起的呢?因为影响MQ消费速度的因素太多了,如下因素只要任何一种出现问题,就会影响MQ消费速度. JVM内存过高,一直在Ful ...

  8. 阿里开源工具——故障在线诊断Arthas

    阿里开源故障诊断工具Arthas(阿尔萨斯) 一.简介 Arthas 是Alibaba于2018 年9月开源的Java诊断工具,深受开发者喜爱.当你遇到以下类似问题而束手无策时,Arthas可以帮助你 ...

  9. 阿里巴巴开源性能监控神器Arthas初体验

    如果问性能测试中最难的是哪部分,相信很多人会说"性能调优".确实是这样,性能调优是一个非常复杂.技术含量很高的工作.涉及到的知识面很广.以我多年从业经验来看,在企业里,大多数的性能 ...

最新文章

  1. c语言上机指导实验7,[C语言程序设计上机指导与同步训练(刘迎春张艳霞)]实验7.pdf...
  2. java 1099_【LeetCode(Java) - 1099】小于 K 的两数之和
  3. Kubernetes-连接Harbor仓库拉取镜像
  4. php如何直接使用iview,iview安装使用
  5. python数据的格式输出_python
  6. windows server 2003 IIS下配置PHP
  7. 开源 区块链_区块链如何补充开源
  8. 1045. 快速排序(25)-PAT乙级真题
  9. 500 lines or less_EXCL公式入门——AND和OR
  10. Word绘制跨行表格
  11. 采用SyncToy2.1软件实现两台电脑间文件的自动实时同步(亲测有效)
  12. python3+selenium实现126邮箱登陆并发送邮件
  13. Android打包混淆----APP加密防破解 + 重新签名
  14. 将切割后的小图片还原为大图片
  15. 【洛谷3043】跳楼机(最短路)
  16. 怎么找到appdata文件夹?
  17. 七年级计算机考试知识点,七年级语文重点笔记 必考知识
  18. Python神笔马良案例集简介
  19. iOS 蓝牙 Bluetooth 外围设备 中央设备
  20. 最新!互联网大厂各职级薪资对应关系图(2020年初)

热门文章

  1. cad二次开发-在vs编译软件环境下使用c#语言编写dll文件-添加单行文本
  2. Teamcenter RAC 查找数据集并获取数据集中文件
  3. 365技术网址导航源码附加交易系统
  4. 摄影测量学:期末考试重点总结
  5. 南京大学计算机专业高考选科要求,南京大学2020年拟在浙江招生专业选考科目要求...
  6. 【创建型模式四】建造者模式
  7. Dell1464笔记本安装Win7旗舰版和XP经历
  8. 每天进步一点点——sleep等时间延迟函数
  9. DeBreath 去除呼吸声vst插件中文文档(翻译)
  10. 【应用安全】 使用Java创建和验证JWT