CPU飙高系统反应慢怎么排查?

简介: CPU飙高系统反应慢怎么排查?

什么是CPU


CPU是整个电脑的核心计算资源,对于一个应用程序来说,CPU是最小执行单元是线程



导致CPU飙高的原因


  1. CPU的上下文切换过多,对于CPU来说,同一个时刻下每个CPU核心只能运行一个线程,如果有多个线程要去被执行怎么办,CPU只能通过上下文切换的方式来执行调度不同的线程,上下文切换需要做两个事情,第一个是保存运行中线程的执行状态,第二个是处于等待中的线程恢复执行,这两个过程需要CPU执行内核相关指令,去实现状态的保存和恢复,如果较多的上下文切换,会占据大量的CPU资源,从而使得CPU无法执行用户进程中的真正指令,导致响应速度下降,在java中文件IO,网络IO,锁等待这些都会造成线程阻塞,而线程阻塞就会导致CPU的上下文切换


  1. CPU资源过度消耗,也就是在程序中创建了大量的线程,或者有线程一直占据CPU资源无法被释放,比如说像死循环,CPU利用率过高之后,导致CPU程序中的线程无法去获得CPU的调度从而影响程序的执行效率,所以既然是这两个问题导致CPU利用率较高,可以通过top命令找到利用率较高的进程,在通过Shift+H找到进程中CPU消耗过高的线程,这里有两种情况,



第一种情况CPU利用率过高的线程一直是同一个,也就是线程ID没有变化,说明在程序中存在长期占用CPU没有释放的一个情况,那么这种情况直接通过jstack获得线程Dump日志,定位到线程日志后,就可以找到问题的代码。第二个是CPU利用率过高的线程ID不断变化,那么说明线程创建过多,需要去挑选几个线程ID,通过jstack获得线程Dump中去进行排查,最后有可能定位的结果是程序正常,只是在CPU飙高的那一刻,用户访问量非常大导致系统资源不够,那么这个时候,我们采取的手段是,去增加系统资源



相关文章
|
1月前
|
缓存 关系型数据库 分布式数据库
PolarDB常见问题之数据库cpu突然飙高如何解决
PolarDB是阿里云推出的下一代关系型数据库,具有高性能、高可用性和弹性伸缩能力,适用于大规模数据处理场景。本汇总囊括了PolarDB使用中用户可能遭遇的一系列常见问题及解答,旨在为数据库管理员和开发者提供全面的问题指导,确保数据库平稳运行和优化使用体验。
|
1月前
|
监控 Java 索引
cpu使用率过高和jvm old占用过高排查过程
cpu使用率过高和jvm old占用过高排查过程
67 2
|
2天前
|
Linux 数据处理
Linux中的nproc命令:轻松查看系统CPU核心数
`nproc`命令在Linux中用于查看CPU核心数,简洁高效,无参数直接运行。它读取`/proc/cpuinfo`获取信息,适用于资源分配。例如,`nproc`显示核心数,`nproc --all`(非标准选项,可能需结合其他命令)展示更多详情。在脚本中,可将`nproc`输出赋值给变量以适应动态资源管理。使用时注意文件访问权限,检查结果准确性,并结合其他工具如`lscpu`获取更全面硬件信息。
|
22天前
|
SQL Java Linux
Linux系统cpu飙升到100%排查方案
Linux系统cpu飙升到100%排查方案
17 0
|
1月前
|
Ubuntu Shell 网络安全
【专栏】在Ubuntu 22.04上安装KubeSphere的指南:确保系统至少有4GB内存和2核CPU,安装Docker和docker-compose
【4月更文挑战第28天】在Ubuntu 22.04上安装KubeSphere的指南:确保系统至少有4GB内存和2核CPU,安装Docker和docker-compose。下载安装脚本`curl -sSL https://kubesphere.io/install.sh | bash`,根据提示选择安装选项,等待完成。安装后,通过访问控制台验证安装效果。解决可能出现的错误、网络问题和性能问题,利用KubeSphere提升容器管理效率。本文为顺利安装和使用提供参考。
|
1月前
|
Linux
如何在Linux系统上查看CPU使用率?
以上命令可以帮助你监视和分析Linux系统中的CPU使用率,可以根据需要选择合适的命令进行查看。 买CN2云服务器,免备案服务器,高防服务器,就选蓝易云。百度搜索:蓝易云
23 0
|
1月前
|
Linux
查看服务器的配置,系统,cpu等信息
查看服务器的配置,系统,cpu等信息
64 0
|
1月前
|
Linux
Linux操作系统调优相关工具(一)查看CPU负载相关工具 找出系统中使用CPU最多的进程?
Linux操作系统调优相关工具(一)查看CPU负载相关工具 找出系统中使用CPU最多的进程?
35 0
|
1月前
|
SQL 运维 NoSQL
【Redis 故障排查】「连接失败问题排查和解决」带你总体分析CPU及内存的使用率高问题排查指南及方案
【Redis 故障排查】「连接失败问题排查和解决」带你总体分析CPU及内存的使用率高问题排查指南及方案
72 0
|
1月前
|
运维 Linux 调度
Linux系统调优详解(十)——CPU调优
Linux系统调优详解(十)——CPU调优
93 3

相关实验场景

更多