Arthas线上项目BUG调试实例分析
导读:本文共4400字符,通常情况下阅读需要15分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: Arthas简介Arthas是Alibaba开源的Java诊断利器,深受开发者喜爱,目前在Github上已有29K+Star。它采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。ArthasTunnel为了演示一个更加真实的线上环境,接下来我们将对Docker容器中的SpringBoot应用进行诊断。我们将使用Arthas... ...
目录
(为您整理了一些要点),点击可以直达。Arthas简介
Arthas是Alibaba开源的Java诊断利器,深受开发者喜爱,目前在Github上已有29K+Star
。它采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。
ArthasTunnel
为了演示一个更加真实的线上环境,接下来我们将对Docker容器中的SpringBoot应用进行诊断。我们将使用
ArthasTunnel
来实现,ArthasTunnel
相当于一个Web控制台,使用它我们无需进入应用容器即可对应用进行诊断,非常方便。
首先我们需要下载ArthasTunnel
的安装包
由于官方只提供了JAR包,如果你想通过Docker方式启动的话,可以自行打包Docker镜像,打包使用的Dockerfile脚本如下:
#该镜像需要依赖的基础镜像FROMjava:8#将当前目录下的jar包复制到docker容器的/目录下ADDarthas-tunnel-server.jar/arthas-tunnel-server.jar#声明服务运行的端口EXPOSE80807777#指定docker容器启动时运行jar包ENTRYPOINT["java","-jar","/arthas-tunnel-server.jar"]#指定维护者的名字MAINTAINERmacro
这里再提供一个一键打包运行ArthasTunnel
容器的执行脚本run.sh
,脚本内容如下;
#!/usr/bin/envbash#定义应用组名group_name='mall-tiny'#定义应用名称app_name='arthas-tunnel-server'#定义应用版本app_version='1.0-SNAPSHOT'echo'----copyjar----'dockerstop${app_name}echo'----stopcontainer----'dockerrm${app_name}echo'----rmcontainer----'dockerrmi${group_name}/${app_name}:${app_version}echo'----rmimage----'#打包编译docker镜像dockerbuild-t${group_name}/${app_name}:${app_version}.echo'----buildimage----'dockerrun-p8080:8080-p7777:7777--name${app_name}\-eTZ="Asia/Shanghai"\-v/etc/localtime:/etc/localtime\-v/mydata/app/${app_name}/logs:/var/logs\-d${group_name}/${app_name}:${app_version}echo'----startcontainer----'
接下来吧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-id
,ArthasTunnel
连接需要使用,由于我们将会把应用容器通过--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控制台中输入AgentId
为mall-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
级别
</div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
Arthas线上项目BUG调试实例分析的详细内容,希望对您有所帮助,信息来源于网络。