首页 > 其他分享 >一线大厂面试真题--CPU飙高系统反应慢怎么排查

一线大厂面试真题--CPU飙高系统反应慢怎么排查

时间:2024-01-14 12:33:09浏览次数:27  
标签:执行 真题 -- 利用率 飙高 线程 上下文 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飙高这个现象的原因,并说出你的解决思路,通过面试是没问题的。

标签:执行,真题,--,利用率,飙高,线程,上下文,CPU
From: https://blog.51cto.com/u_2325151/9240343

相关文章

  • 基于SSM的在线房屋租赁和电子签约系统
    随着信息技术在管理上越来越深入而广泛的应用,实现在线房屋租赁和电子签约系统的设计与实现在技术上已成熟。本文介绍了在线房屋租赁和电子签约系统的设计与实现的开发全过程。通过分析企业对于在线房屋租赁和电子签约系统的设计与实现的需求,创建了一个计算机管理在线房屋租赁和电子......
  • 无涯教程-LISP - 输入&输出
    常见的LISP提供许多输入输出函数,我们已经使用了格式化函数和打印函数进行输出,在本节中,我们将研究LISP中提供的一些最常用的输入输出函数。Read函数下表提供了LISP最常用的输入函数-Sr.No.Function&描述1read&optionalinput-streameof-error-peof-valuerecursive-p......
  • React 系列 useImperativeHandle
    ReactHooks为我们提供了一种全新的方式来处理组件的状态和生命周期。其中,useImperativeHandle 是一个相对较少被提及的Hook,但在某些场景下,它是非常有用的。本文将深入探讨 useImperativeHandle 的用法,并通过实例来加深理解。什么是 useImperativeHandle?useImperativeHandle......
  • 性能篇:深入源码解析和性能测试arraylist和LinkedList差异!
    嗨,大家好,我是小米!今天我们要谈论的是Java中两个常用的集合类:ArrayList和LinkedList。大家都知道,这两者在新增和删除元素的操作上有一些差异,那么它们究竟在性能上有何表现呢?我们通过深入源码解析和性能测试来一探究竟!ArrayList新增元素到末尾这是最常见的新增元素操作,我们使用......
  • Oracle怎样写一个sql,将一个不同的表结构的数据迁移到另一个表中,其中有字段需要有映射
    要将一个表的数据迁移到另一个表,并且需要进行字段映射和值转换,可以使用以下步骤:创建目标表:CREATETABLE目标表名(目标字段1数据类型,目标字段2数据类型,...);插入数据并进行字段映射和值转换:INSERTINTO目标表名(目标字段1,目标字段2,...)SELECTCASEWH......
  • # yyds干货盘点 # 盘点一个AI解答疑难代码的问题
    大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas代码解读的问题,问题如下:df_in=df[df['入/出'].eq('入')],我也不懂eq啥意思?感觉这代码还可以写成df[df['入/出']=='入'],这两段一个意思吧。答:eq就是=,就是你说的这个。二、实现过程后来【论草莓如......
  • 动态链接库的生成和使用
    1、当前目录/home/xuanmiao/Demo/LSPT/Test创建文件prime.h和prime.cprime.hintisprime(longintnumber);prime.cintisprime(longintnumber){longintj;intprime=1;/*Testifthenumberisdivisible,starting*from2*/for(j=2;......
  • Makefile wildcard
    TPLOAD_SRCS=$(wildcard$(TPLOAD_DIR)/*.c)TPLOAD_OBJS=$(patsubst%.c,%.o,$(TPLOAD_SRCS))一般我们可以使用“$(wildcard*.c)”来获取工作目录下的所有的.c文件列表。复杂一些用法可以使用“$(patsubst%.c,%.o,$(wildcard*.c))”,首先使用“wildcard”函数获取工作目......
  • ARC151D Binary Representations and Queries
    ARC151DBinaryRepresentationsandQueries题目链接:ARC151DBinaryRepresentationsandQueries非常好思维题。思路首先我们会发现每个操作都是\(\frac{n}{2}\)的\(A_i\),给另外\(\frac{n}{2}\)的\(A_j\)的增加。这题直接去维护每个操作时间复杂度会开心的笑。所以......
  • 吴师兄学算法day06 485. 最大连续 1 的个数
    题目:485. 最大连续1的个数易错点:第一眼想到从队尾开始交换,后来发现不行。 代码示例:classSolution:defmoveZeroes(self,nums:List[int])->None:"""Donotreturnanything,modifynumsin-placeinstead."""slow=......