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

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

相关推荐
疯狂踩坑人3 小时前
【Python版 2026 从零学Langchain 1.x】(二)结构化输出和工具调用
后端·python·langchain
今天_也很困4 小时前
LeetCode热题100-560. 和为 K 的子数组
java·算法·leetcode
在繁华处4 小时前
线程进阶: 无人机自动防空平台开发教程V2
java·无人机
A懿轩A4 小时前
【Java 基础编程】Java 变量与八大基本数据类型详解:从声明到类型转换,零基础也能看懂
java·开发语言·python
m0_740043734 小时前
【无标题】
java·spring boot·spring·spring cloud·微服务
橘子师兄5 小时前
C++AI大模型接入SDK—ChatSDK封装
开发语言·c++·人工智能·后端
@ chen5 小时前
Spring事务 核心知识
java·后端·spring
aithinker5 小时前
使用QQ邮箱收发邮件遇到的坑 有些WIFI不支持ipv6
java
星火开发设计5 小时前
C++ 预处理指令:#include、#define 与条件编译
java·开发语言·c++·学习·算法·知识