【面试普通人VS高手系列】CPU飙高系统反应慢怎么排查?
面试过程中,场景类的问题更容易检测出一个开发人员的基本能力。 这不,一个小伙伴去阿里面试,第一面就遇到了关于“CPU飙高系统反应慢怎么排查”的问题? 对于这个问题,我们来看看普通人和高手的回答!
普通人:
嗯, CPU飙高的原因可能是线程创建过多导致的。
高手:
好的,关于这个问题,我从四个方面来回答。
CPU是整个电脑的核心计算资源,对于一个应用进程来说,CPU的最小执行单元是线程。
导致CPU飙高的原因有几个方面
CPU上下文切换过多,对于CPU来说,同一时刻下每个CPU核心只能运行一个线程,如果有多个线程要执行,CPU只能通过上下文切换的方式来执行不同的线程。上下文切换需要做两个事情
保存运行线程的执行状态- 让处于等待中的线程执行
这两个过程需要CPU执行内核相关指令实现状态保存,如果较多的上下文切换会占据大量CPU资源,从而使得cpu无法去执行用户进程中的指令,导致响应速度下降。
在Java中,文件IO、网络IO、锁等待、线程阻塞等操作都会造成线程阻塞从而触发上下文切换
CPU资源过度消耗,也就是在程序中创建了大量的线程,或者有线程一直占用CPU资源无法被释放,比如死循环!
CPU利用率过高之后,导致应用中的线程无法获得CPU的调度,从而影响程序的执行效率!
既然是这两个问题导致的CPU利用率较高,于是我们可以通过
top命令,找到CPU利用率较高的进程,在通过
Shift+H找到进程中CPU消耗过高的线程,这里有两种情况。
-
CPU利用率过高的线程一直是同一个,说明程序中存在线程长期占用CPU没有释放的情况,这种情况直接通过jstack获得线程的Dump日志,定位到线程日志后就可以找到问题的代码。
最后有可能定位的结果是程序正常,只是在CPU飙高的那一刻,用户访问量较大,导致系统资源不够。
以上就是我对这个问题的理解!
总结:
从这个问题来看,面试官主要考察实操能力,以及解决问题的思路。
如果你没有实操过,但是你知道导致CPU飙高这个现象的原因,并说出你的解决思路,通过面试是没问题的。
如果你在面试的时候遇到了一些比较刁钻也奇葩的问题,欢迎私信或在评论区给我留言。
我是Mic,一个工作了14年的Java程序员,咱们下篇文章再见。
- 【面试普通人VS高手系列】lock和synchronized区别
- 【面试普通人VS高手系列】线程池如何知道一个线程的任务已经执行完成
- 平时碰到系统CPU飙高和频繁GC,你会怎么排查?
- 被面试官疯狂追问:平时碰到系统CPU飙高和频繁GC,你会怎么排查?我太难了
- 面试官:生产环境碰到系统CPU飙高和频繁GC,你要怎么排查?
- Windows10 64位系统下成功安装Caffe(CPU+VS 2013)
- 云服务器 ECS Linux 系统 CPU 占用率较高问题排查思路
- 【Spark亚太研究院系列丛书】Spark实战高手之路-第一章 构建Spark集群-运行Ubuntu系统(2)
- 线上CPU100%?看看这篇是怎么排查的!
- (高手进)怎么修改Ghost封装自己的系统
- 【Spark亚太研究院系列丛书】Spark实战高手之路-第一章 构建Spark集群-安装Ubuntu系统(2)
- Linux系统中CPU占用率较高问题排查思路与解决方法
- 获取XP系统用户名和密码,怎么不行啊,那位高手帮一一下,,
- 金蝶K3无法进入系统、反应卡慢怎么解决
- linux嵌入式编程高手历程系列8-NFS网络文件系统配置方法
- 【Java进阶面试系列之一】哥们,你们的系统架构中为什么要引入消息中间件?
- (DT系列三)系统启动时, dts 是怎么被加载的
- 尴尬的面试现场:说说你们系统有多大QPS?系统到底怎么抗住高并发的?
- 面试问题---JAVA程序CPU占用过高怎么定位
- 面试100题系列之8单词反转 VS HDU1062——text reverse