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

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、使用异步编程

相关推荐
abyyyyy123几秒前
oj题目练习
java·前端·数据库
有一个好名字2 分钟前
JAVA虚拟机-JVM
java·开发语言·jvm
玄〤9 分钟前
枚举问题的两大利器:深度优先搜索(DFS)与下一个排列(Next Permutation)算法详解(Java版本)(漫画解析)
java·算法·深度优先·dfs
wuqingshun31415914 分钟前
HashMap的长度为什么是2的N次方呢?
java·开发语言·jvm
Loo国昌21 分钟前
【AI应用开发实战】04_混合检索器:BM25+向量+可靠度融合实战
人工智能·后端·python·自然语言处理
indexsunny27 分钟前
互联网大厂Java面试实录:Spring Boot与微服务在电商场景中的应用
java·jvm·spring boot·微服务·面试·mybatis·电商
予枫的编程笔记31 分钟前
【Kafka基础篇】Kafka高可用核心:ISR机制与ACK策略详解,吃透可靠性与吞吐量权衡
java·kafka·消息队列·高可用·分布式系统·isr机制·ack策略
先做个垃圾出来………34 分钟前
Flask框架特点对比
后端·python·flask
时734 分钟前
Java 版本管理工具:Jabba
java
开源fly37 分钟前
Java泛型和类型擦除
java