排查工具 - Arthas
官方介绍
Arthas 是一款线上监控诊断产品,通过全局视角实时查看应用 load、内存、gc、线程的状态信息,并能在不修改应用代码的情况下,对业务问题进行诊断,包括查看方法调用的出入参、异常,监测方法执行耗时,类加载信息等,大大提升线上问题排查效率。
安装
参考官方文档:https://arthas.aliyun.com/doc/install-detail.html
我的排查过程
设置Docker容器权限
这一步很重要,如果docker容器没有相应的权限,在执行Arthas的一些命令时会报错:
AsyncProfiler error: No access to perf events. Try --fdtransfer or --all-user option or ‘sysctl kernel.perf_event_paranoid=1’
设置方法
这个设置方法有很多,还和你启动容器的方式有关,可以自行百度,我的容器是通过docker-compose.yml进行配置并启动的,配置如下:
version: "3.7"
services:
datain-backend:
image: xxxx:version
privileged: true
ports:
- 8080:8080
启动容器并获取容器ID
启动容器
docker-compose up -d
获取容器ID
docker ps
进入容器
docker exec -it 容器ID /bin/bash