Arthas常用方式

javascript 复制代码
# 查看内存概览信息CPU和内存占用率是否需要调整参数
dashboard
javascript 复制代码
# CPU飙高看占用最高的 3 个线程堆栈(比top + jstack 快)
thread -n 3

# 查看特定 ID 线程的详细堆栈和状态
thread <ID>

# 检查是否存在死锁线程
thread -b
javascript 复制代码
# 不重启服务前提临时修改日志级别,用于排除问题,因为生产环境通常是warn 级别的自己打印的日志一般是info,线上就看不到自己的日志
logger --name <你的包名> --level DEBUG
logger --name com.ldj.springboot.importbean.controller --level INFO
javascript 复制代码
# 监控方法的出入参数,深度3,只看5次自动停止
watch <类名> <方法名> '表达式' [可选项]

watch com.ldj.springboot.importbean.ISpringBootApplication test '{params, returnObj}' -x 3 -n 5
javascript 复制代码
# 查看调用链路中那个方法耗时久,哪个方法是性能瓶颈
trace <com.xxx.类名> <方法名>

watch com.ldj.springboot.importbean.ISpringBootApplication test

在线临时少量修复bug代码 (不推荐这样操作,一般是在紧急情况 临时修改开关 或者关键配置参数会这样做)

javascript 复制代码
# 获取 ClassLoader Hashid
sc -d com.ldj.springboot.importbean.controller.TestController

# 反编译java代码
jad --source-only com.ldj.springboot.importbean.controller.TestController > /tmp/TestController.java

# 修改bug代码
vi /tmp/TestController.java

# 重新编译修改后的代码,window系统默认将它输出到E盘
mc -c 18b4aac2 /tmp/TestController.java

# 热加载,把上面的输出路径复制下来
retransform /tmp/com/ldj/springboot/importbean/controller/TestController.class

# 如果是window系统,热加载改成下面这样
retransform "E:\javaWeb\spring-boot-study\com\ldj\springboot\importbean\controller\TestController.class"

window系统实操例子

相关推荐
m0_741173331 小时前
如何处理SQL中的NULL值_使用ISNULL或COALESCE函数
jvm·数据库·python
步辞2 小时前
css伪类选择器-nth-child应用技巧_循环选择列表或表格行的实现方法
jvm·数据库·python
2301_803875613 小时前
Python怎么计算NumPy数组的切比雪夫距离_使用abs与max求解
jvm·数据库·python
qq_349317483 小时前
CSS如何实现Bootstrap进度条自定义动画_利用keyframe关键帧
jvm·数据库·python
2401_871492853 小时前
Python机器学习怎么防止数据泄漏_确保Scaler在Pipeline内拟合
jvm·数据库·python
2301_818008443 小时前
MySQL怎样在触发器中引用新旧数据行_NEW与OLD关键字详解
jvm·数据库·python
qq_372154237 小时前
如何配置表中某列的排序权重_全文索引配置与权重分配
jvm·数据库·python
2501_914245937 小时前
CSS如何使用-nth-of-type精确选择列表项_通过元素类型限制提升样式健壮性
jvm·数据库·python
吕源林7 小时前
Golang如何做本地缓存加速_Golang本地缓存教程【核心】
jvm·数据库·python
weixin_381288188 小时前
Layui怎么在表格标题栏中嵌入一个迷你的HTML搜索表单
jvm·数据库·python