【实战】监控上下文切换及其优化方案

PS:指令中的14222为进程ID

1、使用 jps 获取进程id
复制代码
# 显示完整类名
jps -l

# 输出:
# 14222 /path/to/ReduceContextSwitchDemo.jar
# 14223 sun.tools.jps.Jps

# 显示 JVM 参数
jps -v

# 显示传递给 main 的参数
jps -m

2、导出并查看线程堆栈
复制代码
# 导出到文件
jstack 14222 > dump_high_concurrency.txt

# 或者直接查看
jstack 14222 | less

# Linux/Mac
cat dump_high_concurrency.txt

3、统计线程状态

统计各状态线程数量

复制代码
# 方式1:使用 grep + sort + uniq
jstack 14222 | grep "java.lang.Thread.State" | sort | uniq -c

# 方式2:使用 awk(更简洁)
jstack 14222 | grep "Thread.State:" | cut -d: -f2 | sort | uniq -c

# 方式3:从文件统计
grep "Thread.State:" dump_high_concurrency.txt | cut -d: -f2 | sort | uniq -c

查找 WAITING 线程详情

复制代码
# 查看所有 WAITING 线程
grep -A 5 "WAITING (on object monitor)" dump_high_concurrency.txt | head -30

# 统计 WAITING 线程在等待什么
grep -A 3 "WAITING (on object monitor)" dump_high_concurrency.txt | grep "at " | sort | uniq -c

4、观察系统性能指标

监控上下文切换

复制代码
# 实时监控(每秒刷新)
vmstat 1

# 输出示例:
# procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
#  r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
#  2  0      0 1234567  12345 123456    0    0     0     0  123 5678  1  1 98  0  0
#                                                            ↑    ↑
#                                                           in   cs
# in = interrupts (中断次数)
# cs = context switches (上下文切换次数)

监控 CPU 使用率

复制代码
# 查看 CPU 使用情况
top -H -p 14222

# 或使用 htop(更直观)
htop -p 14222

监控线程数

复制代码
# 查看进程的线程数
ps -eLf | grep 14222 | wc -l

# 或使用 top
top -H -p 14222
# 按 'H' 键切换线程视图

优化方案

1、合理创建线程池

2、减少锁竞争,减少锁的粒度

3、避免不必要的竞争

4、使用异步编程

相关推荐
代龙涛1 小时前
WordPress 主题初体验:从 style.css 到 index.php、single.php 简单实战
后端·php·wordpress
zzb15808 小时前
RAG from Scratch-优化-query
java·数据库·人工智能·后端·spring·mybatis
wuqingshun3141598 小时前
如何停止一个正在退出的线程
java·开发语言·jvm
Barkamin9 小时前
队列的实现(Java)
java·开发语言
必胜刻9 小时前
RESTful 基础:资源、路径与方法对应关系详解
后端·restful
XPoet9 小时前
AI 编程工程化:Hook——AI 每次操作前后的自动检查站
前端·后端·ai编程
骇客野人9 小时前
自己手搓磁盘清理工具(JAVA版)
java·开发语言
J2虾虾9 小时前
在SpringBoot中使用Druid
java·spring boot·后端·druid
清风徐来QCQ9 小时前
Java笔试总结一
java·开发语言
10Eugene10 小时前
C++/Qt自制八股文
java·开发语言·c++