当前位置: 首页 > news >正文

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

mic老师面试题摘选  
面试过程中,场景类的问题更容易检测出一个开发人员的基本能力。
这不,一个小伙伴去阿里面试,第一面就遇到了关于“CPU 飙高系统反应慢怎么排查”
的问题?
对于这个问题,我们来看看普通人和高手的回答!
普通人
嗯, CPU 飙高的原因可能是线程创建过多导致的
高手
好的,关于这个问题,我从四个方面来回答。
1. CPU 是整个电脑的核心计算资源,对于一个应用进程来说,CPU 的最小执行单元
是线程。
2. 导致 CPU 飙高的原因有几个方面
a. CPU 上下文切换过多,对于 CPU 来说,同一时刻下每个 CPU 核心只能运行一 个线程,如果有多个线程要执行,CPU 只能通过上下文切换的方式来执行不同 的线程。上下文切换需要做两个事情
i. 保存运行线程的执行状态
ii. 让处于等待中的线程执行
这两个过程需要 CPU 执行内核相关指令实现状态保存,如果较多的上下文切换会占据 大量 CPU 资源,从而使得 cpu 无法去执行用户进程中的指令,导致响应速度下降。 在 Java 中,文件 IO、网络 IO、锁等待、线程阻塞等操作都会造成线程阻塞从而触发 上下文切换
b. CPU 资源过度消耗,也就是在程序中创建了大量的线程,或者有线程一直占用 CPU 资源无法被释放,比如死循环!
CPU 利用率过高之后,导致应用中的线程无法获得 CPU 的调度,从而影响程序的执行 效率!
3. 既然是这两个问题导致的 CPU 利用率较高,于是我们可以通过 top 命令,找到 CPU 利用率较高的进程,在通过 Shift+H 找到进程中 CPU 消耗过高的线程,这里有两 种情况。
a. CPU 利用率过高的线程一直是同一个,说明程序中存在线程长期占用 CPU 没 有释放的情况,这种情况直接通过 jstack 获得线程的 Dump 日志,定位到线 程日志后就可以找到问题的代码。
b. CPU 利用率过高的线程 id 不断变化,说明线程创建过多,需要挑选几个线程 id,通过 jstack 去线程 dump 日志中排查。
4. 最后有可能定位的结果是程序正常,只是在 CPU 飙高的那一刻,用户访问量较大, 导致系统资源不够。
以上就是我对这个问题的理解!
结尾
从这个问题来看,面试官主要考察实操能力,以及解决问题的思路。 如果你没有实操过,但是你知道导致 CPU 飙高这个现象的原因,并说出你的解决思路, 通过面试是没问题的。
好的,本期的普通人 VS 高手面试系列的视频就到这里结束了,
http://www.lryc.cn/news/223687.html

相关文章:

  • 深度学习之基于YoloV5-Deepsort人物识别与追踪系统
  • Spring Boot中配置多个数据源
  • C++学习笔记---命名空间namespace
  • 缓存-Spring Cache 缓存抽象
  • Java修仙传之神奇的ES2(巧妙的查询及结果处理篇)
  • 架构设计的课程资料
  • 数据结构与算法C语言版学习笔记(5)-串,匹配算法、KMP算法
  • 新版HI3559AV100开发注意事项
  • Django(一、简介,安装与使用)
  • 【Linux C IO多路复用】多用户聊天系统
  • JSON——数组语法
  • 运营商大数据精准获客:我们提供精准客源渠道的最大资源体?
  • 表象变换与矩阵元
  • vue乾坤微前端项目
  • 大语言模型比武
  • 王道数据结构第五章二叉树的遍历第13题
  • 微服务的发展历程的详细说明及每个阶段主流的架构和组件
  • 2023年眼镜行业分析(京东眼镜销量数据分析):市场规模同比增长26%,消费需求持续释放
  • 基础课26——业务流程分析方法论
  • 【数字图像处理-TUST】实验二-图像噪声生成与滤波降噪
  • bilibili快速升满级(使用Docker 容器脚本)
  • Android 13.0 Settings主页面去掉FocusRecyclerView相关功能
  • Python(四)字符串
  • WPF中ElementName与RelativeSource绑定的局限性以及对策
  • 基于PHP语言的会员系统搭建(Docker版)
  • 文件改名:一次性解决文件名混乱,批量重命名技巧
  • app自动化测试——capability 配置参数解析
  • 数仓面经大框架
  • C++ explicit关键字的作用
  • 排序算法之-冒泡