自带IDEA插件的阿里开源诊断神器Arthas线上项目BUG调试

目录
  • Arthas简介
  • ArthasTunnel
  • SpringBoot集成
  • IDEA插件
  • 总结

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

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

Arthas简介

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

ArthasTunnel

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

首先我们需要下载ArthasTunnel的安装包,下载地址:

https://github.com/alibaba/arthas/releases

由于官方只提供了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-arthas
  tunnel-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使用教程 。

参考资料

项目官网:https://github.com/alibaba/arthas

官方文档:https://arthas.aliyun.com/doc/index.html

DEA插件使用文档:https://www.yuque.com/arthas-idea-plugin

项目源码地址

https://github.com/macrozheng/mall-learning/tree/master/mall-tiny-arthas2

更多关于Arthas线上项目BUG调试的资料请关注我们其它相关文章!

(0)

相关推荐

  • 自带IDEA插件的阿里开源诊断神器Arthas线上项目BUG调试

    目录 前 Arthas简介 ArthasTunnel SpringBoot集成 IDEA插件 总结 前 记得之前写过一篇Arthas使用教程,通过使用Arthas我们既可以实现线上调试,还可以实现热修复.最近逛了下Arthas的官网,发现它已经支持直接集成到SpringBoot应用中去,并且还出了专用的IDEA插件.今天我们再来体验下它,看看它的功能是不是更强大了! SpringBoot实战电商项目mall(50k+star)地址:https://github.com/macrozheng/ma

  • Java开源诊断工具Arthas使用方法详解

    一.前言 1.热更新代码的场景 (1)当线上服务器出现问题时,有些时候现有的手段不足以发现问题所在,可能需要追加打印日志或者增加一些调试代码,如果我们去改代码重新部署,会破坏问题现场,可以通过热部署的手段来增加调试代码 (2)线上出现紧急bug,通过Review代码找到问题,修改好后打包部署的流程可能比较久,可以通过热部署代码及时解决问题 二.使用阿里巴巴开源的Java诊断工具 ---Arthas,他可以附着在我们的Java服务器进程上面,查看服务器状态,jvm状态等各种参数指标,还可以进行热更

  • 阿里开源低代码引擎和生态建设实战及思考

    目录 前言 第一部分 - 低代码体系的架构设计思考 第二部分 - 求同:阿里低代码引擎&UIPaaS 第三部分 - 存异:百花齐放的低代码平台 彩蛋 - 协议对外开放 & 低代码引擎开源 前言 大家好,今天很开心有机会跟大家分享最近几年阿里在低代码领域的思考和实战. 我是力皓,目前已经在前端和后端岗位工作了十多年了,近 3 年专注在低代码领域,是阿里低代码引擎项目负责人. 我的部门是企业智能事业部,我们部门有大量中后台场景,所以我们在 6 年前就开始低代码领域的探索了,并且一直在持续投入,

  • springboot框架阿里开源低代码工具LowCodeEngine

    目录 前言 LowCodeEngine简介 搭建低代码平台 使用低代码平台 目标效果 总结 前言 解放双手!推荐一款阿里开源的低代码工具,YYDS! 之前分享过一些低代码相关的文章,发现大家还是比较感兴趣的.之前在我印象中低代码就是通过图形化界面来生成代码而已,其实真正的低代码不仅要负责生成代码,还要负责代码的维护,把它当做一站式开发平台也不为过!最近体验了一把阿里开源的低代码工具LowCodeEngine,确实是一款面向企业级的低代码解决方案,推荐给大家! SpringBoot实战电商项目ma

  • Spring Boot整合阿里开源中间件Canal实现数据增量同步

    目录 前言 Canal是什么? Canal数据如何传输? 数据同步还有其他中间件吗? Canal服务端安装 1.打开MySQL的binlog日志 2.设置MySQL的配置 3.设置RabbitMQ的配置 4.RabbitMQ新建exchange和Queue 5.启动服务端 6.测试 Canal客户端搭建 1.创建消息实体类 2.MQ消息监听业务 3.测试 总结 前言 数据同步一直是一个令人头疼的问题.在业务量小,场景不多,数据量不大的情况下我们可能会选择在项目中直接写一些定时任务手动处理数据,例

  • JS实现带关闭功能的阿里妈妈网站顶部滑出banner工具条代码

    本文实例讲述了JS实现带关闭功能的阿里妈妈网站顶部滑出banner工具条代码.分享给大家供大家参考.具体如下: 这是一款阿里妈妈网站顶部banner代码,采用滑出的方式,一个经典的工具条代码,可以当作菜单来用,同时还有完善的功能,可以适时关闭工具条,整体效果设计美观,简洁漂亮. 运行效果截图如下: 在线演示地址如下: http://demo.jb51.net/js/2015/js-top-float-banner-alimama-style-codes/ 具体代码如下: <!DOCTYPE ht

  • Spring Boot结合IDEA自带Maven插件如何快速切换profile

    目录 一.前言 二.配置详情 2.1 pom.xml修改 2.2 bootstrap.yml/application.yml修改 一.前言 IDEA是目前 Java 开发者中使用最多的开发工具,它有着简约的设计风格,强大的集成工具,便利的快捷键. 在项目项目整个开发运维周期中,我们的的项目往往需要根据不同的环境,使用不同的文件配置. 比如以下部分: 默认:application.properties/yml 共用配置:application-common.properties/yml 开发环境:

  • SpringBoot Admin集成诊断利器Arthas示例实现

    目录 前言 SpringBoot Admin SBA 集成 客户端配置 在配置中心加入配置 实现开关效果 结束 前言 Arthas 是 Alibaba开源的Java诊断工具,具有实时查看系统的运行状况,查看函数调用参数.返回值和异常,在线热更新代码,秒解决类冲突问题.定位类加载路径,生成热点图,通过网页诊断线上应用.  如今在各大厂都有广泛应用,也延伸出很多产品. 这里将介绍如何将Arthas集成进SpringBoot监控平台中. SpringBoot Admin 为了方便SpringBoot

  • 详解Alibaba Java诊断工具Arthas查看Dubbo动态代理类

    目录 阅读Dubbo源码过程中,会发现,Dubbo消费端在做远程调用时,默认通过 Javassist 框架为服务接口生成动态代理类,调用javassist框架下的JavassistProxyFactory类的getProxy(Invoker invoker, Class<?>[] interfaces)方法,动态生成一个存放在JVM中的动态代理类. public <T> T getProxy(Invoker<T> invoker, Class<?>[] in

  • SpringBoot整合java诊断工具Arthas解读

    目录 一.Arthas官方文档 二.springBoot整合方式 1.pom文件引入 2.yaml文件引入 3.下载arthas-tunnel-server 4.启动Arthas Tunnel Server及spring项目 5.登录Arthas Tunnel Server 6.输入命令进行测试 总结 一.Arthas官方文档 https://arthas.aliyun.com/doc/ 二.springBoot整合方式 1.pom文件引入 <dependency> <groupId&g

随机推荐