linux查看cpu性能模式 Linux性能监测CPU篇
linux查看cpu性能模式 Linux性能监测CPU篇
2024-11-22 08:36:11  作者:皇家之花  网址:https://m.xinb2b.cn/life/lnd309477.html


Linux性能监测:CPU篇

前言

接前一篇《Linux性能监测:介绍篇》,性能是一个永恒的话题。我们公司的运维管理员每天都收到各种告警短信,一会这个主机的CPU触发阈值了,一会那个主机的CPU也触发阈值了。当运维管理员收到这种短信的时候,运维管理员就需要形成以下条件反射,或者说,运维管理员就需要具备以下知识储备。

什么是CPU?CPU过高会带来哪些问题?如何检查CPU健康状态?如何定位CPU过高的根源?

所以说,只有具备了扎实的基本功,才能从容面对性能难题。对于上面的问题,接下来,我们将一一进行回答和总结。

什么是CPU

引用百度百科里的解释:中央处理器(CPU,Central Processing Unit)是一块超大规模的集成电路,是一台计算机的运算核心(Core)和控制核心(Control Unit)。它的功能主要是解释计算机指令以及处理计算机软件中的数据。CPU主要包括运算器(算术逻辑运算单元,ALU,Arithmetic Logic Unit)和高速缓冲存储器(Cache)及实现它们之间联系的数据(Data)、控制及状态的总线(Bus)。它与内部存储器(Memory)和输入/输出(I/O)设备合称为电子计算机三大核心部件。

CPU的主要功能是解释计算机指令以及处理计算机软件中的数据,并执行指令。说简单点,就是我们编写的程序,经过编译后,最终都会变成一条条的指令,由CPU来进行最终的执行。通常CPU的运算速度、主频、缓存、核心数,这几个参数就决定了CPU的好坏,一般情况下,CPU的主频越高、缓存越大、核心数越多,这样的CPU运转速度就很快,处理图形图像文件起来,速度就越快,这种CPU的价格就比较贵。

除了上面的一些定义和常识外,我们还需要明白一些特殊名词的含义。

物理CPU

主板上实际插入的cpu数量;这个是物理存在的设备。打开主板,我们是可以肉眼看到的。在Linux服务器上,我们可以通过以下命令查看物理CPU个数:cat /proc/cpuinfo | grep "physical id" | sort | uniq | wc -l

CPU核数

核数就是指CPU上集中的处理数据的cpu核心个数,单核指cpu核心数一个,双核则指的是两个。通常每个CPU下的核数都是固定的,比如你的计算机有两个物理CPU,每个CPU是双核,那么计算机就是四核的。在Linux服务器上,我们可以通过以下命令查看CPU核数:cat /proc/cpuinfo | grep "cpu cores" | wc -l

逻辑CPU

一般情况下,逻辑CPU=物理CPU个数×每颗核数,如果不相等的话,则表示服务器的CPU支持超线程技术(HT:简单来说,它可使处理器中的1颗内核像2颗内核那样在操作系统中发挥作用。这样一来,操作系统可使用的执行资源扩大了一倍,大幅提高了系统的整体性能,此时逻辑CPU=物理CPU个数×每颗核数x2);可以通过以下命令来查看逻辑CPU个数:cat /proc/cpuinfo | grep "processor" | wc -l

CPU过高会带来哪些问题

我们收到CPU过高的告警,我们一般都需要紧急对应的。我们都知道,CPU是用来运行各种程序,做各种计算的,一旦CPU处于高负荷状态,容易引起服务响应速度变慢,进而导致整个服务不可用,特别是在业务高峰期可能导致雪崩效应,最终整个系统出现瘫痪。所以,一旦出现CPU过高的告警,我们一定要谨慎、认真对待。

如何检查CPU健康状态

我们都知道复制文件通常占用较少CPU,因为大部分工作是由DMA完成,只是在完成复制以后给一个中断让CPU知道复制已经完成;科学计算通常占用较多的CPU,大部分计算工作都需要在CPU上完成,内存、硬盘等子系统只做暂时的数据存储工作。要想监测和理解CPU的性能需要知道一些操作系统的基本知识,比如:中断、进程调度、进程上下文切换、可运行队列等。这里我们用个例子来简单介绍一下这些概念和他们的关系,CPU很无辜,是个任劳任怨的打工仔,每时每刻都有工作在做(进程、线程)并且自己有一张工作清单(可运行队列),由老板(进程调度)来决定他该干什么,他需要和老板沟通以便得到老板的想法并及时调整自己的工作(上下文切换),部分工作做完以后还需要及时向老板汇报(中断),所以打工仔(CPU)除了做自己该做的工作以外,还有大量时间和精力花在沟通和汇报上。

CPU也是一种硬件资源,和任何其他硬件设备一样也需要驱动和管理程序才能使用,我们可以把内核的进程调度看作是CPU的管理程序,用来管理和分配CPU资源,合理安排进程抢占CPU,并决定哪个进程该使用CPU、哪个进程该等待。操作系统内核里的进程调度主要用来调度两类资源:进程(或线程)和中断,进程调度给不同的资源分配了不同的优先级,优先级最高的是硬件中断,其次是内核(系统)进程,最后是用户进程。每个CPU都维护着一个可运行队列,用来存放那些可运行的线程。线程要么在睡眠状态(blocked 正在等待 IO)要么在可运行状态,如果CPU当前负载太高而新的请求不断,就会出现进程调度暂时应付不过来的情况,这个时候就不得不把线程暂时放到可运行队列里。我们在这里要讨论的是性能监测,而上面谈了一堆都没提到性能,那么这些概念和性能监测有什么关系呢?关系重大。如果你是老板,你如何检查打工仔的效率(性能)呢?我们一般会通过以下这些信息来判断打工仔是否偷懒:

打工仔接受和完成多少任务并向老板汇报了(中断);打工仔和老板沟通、协商每项工作的工作进度(上下文切换);打工仔的工作列表是不是都有排满(可运行队列);打工仔工作效率如何,是不是在偷懒(CPU 利用率)。

现在把打工仔换成CPU,我们可以通过查看这些重要参数:中断、上下文切换、可运行队列、CPU利用率来监测 CPU的性能。

要监控CPU的性能,那我们就必须先知道每个参数的健康区间,一个评判的标准,这样才能初步判断CPU的健康状况。

CPU利用率;如果CPU有100%利用率,那么应该到达这样一个平衡:65%-70% User Time30%-35% System Time0%-5% Idle Time上下文切换;上下文切换应该和CPU利用率联系起来看,如果能保持上面的CPU利用率平衡,大量的上下文切换是可以接受的;可运行队列;每个可运行队列不应该超过3个线程(每处理器),比如:双处理器系统的可运行队列里不应该超过6个线程。

确定了评判标准后,那我们就需要通过工具实时的查看系统的这些重要参数是否在健康标准范围之内。而我这里将重点介绍vmstat和top这两个工具。

《Linux vmstat命令详解》《Linux top命令详解》如何定位CPU过高的根源

如果定位CPU过高的根源,这完全是一个技术活和经验活;也就是说,如果你不是一个“老中医”的话,处理这种问题就比较吃劲了。要定位CPU过高的根源,首先我们需要知道这台服务器上跑了写什么应用,这个是最起码的。同时,我们也需要积累一些经验,哪些操作会引起CPU过高。

除了通过上面的工具找到具体导致CPU飙升的进程和线程后,我们要根据部署的应用类型来做具体的分析。比如Java类的应用如何定位CPU飙升的问题。

总结

关于CPU篇就总结到此结束。这篇文章完全按照实际的工作要求进行的总结,源于工作,但是内容多余工作,掌握了这篇文章中的内容,能够让你基本能够了解性能中关于CPU的内容,也能够让你在日后的工作中从容的面对CPU性能问题。

果冻想,认真玩技术的地方。

2018年12月23日,于内蒙古呼和浩特。

  • 换热器常见的清洗方法(五点简述换热器的清洗意义)
  • 2024-11-22五点简述换热器的清洗意义换热器作为非常重要的热交换设备,是实现不同温度介质间热量传递的节能设备换热器结构性能的优劣,将会影响设备节能效果及安全长周期运行,所以定期清洗换热器就特别重要(1)美化设备外观,净化生产环境清楚设备内。
  • 东海航空机长乘务员互殴原(网传机长乘务长客舱互殴)
  • 2024-11-22网传机长乘务长客舱互殴3月6日,网络上曝出一则消息:东海航空DZ6297航班(南通-西安)的航班上,机长与乘务长发生争执,在飞行过程中相互殴打,机长将乘务长手打骨折,乘务长把机长门牙敲掉半颗@东海航空3月7日回应称,感谢社。
  • 你们不要过来啊小说(叫你进来就进来呗)
  • 2024-11-22叫你进来就进来呗李思思惊呆了她睁大双眼一直盯着王四喜看,然而这个时候周围都围满了人,如果这个时候李思思有什么反常的举动的话,便会被大伙儿都知晓在青石沟这个闭塞的小村庄里,早就有一个这么不成文的规定,如果哪个大姑娘被人。
  • 描写植物的诗词大全 这些诗词中的植物名
  • 2024-11-22描写植物的诗词大全 这些诗词中的植物名夏日已至,满目葱茏菜场里,有品类丰富的瓜果蔬菜;公园里,是枝繁叶茂的花草树木那些叫不上名来的植物,是不是难住了你呢?可哪怕看到它们的名字,又在读音上犯了愁名字,是了解一个人的开始,在植物界也是如此今天。
  • 生肖是按农历还是阳历(生肖的简述)
  • 2024-11-22生肖的简述生肖是按农历算的生肖,又被称为属相,主要由十二种动物组成,分别是:鼠、牛、虎、兔、龙、蛇、马、羊、猴、鸡、狗、猪其中,鼠代表的是“子时”;牛代表的是“丑时”;虎代表的是“寅时”;兔代表的是“卯时”;龙。
  • pdd逆水寒还玩么(PDD时代变了逆水寒真成好玩不花钱了)
  • 2024-11-22PDD时代变了逆水寒真成好玩不花钱了PDD的老兵服之旅PDD回归《逆水寒》魔兽老兵服了,但似乎他的游戏生涯并非一帆风顺在一众主播里,PDD可以说是最知名的MMO死忠之一了而其中最为人熟知的,还是他《逆水寒》神壕的身份,当初为了打造账号“。
  • 辛亥革命110周年谈发展(上游君读历史1911年今日)
  • 2024-11-22上游君读历史1911年今日辛亥革命104周年〈1911年10月10日——2015年10月10日〉(本文图片来源于百度百科)辛亥革命的定义广义:指以孙中山为首要革命党人为推翻清王朝,建立资产阶级共和国而进行的一系列努力;狭义:1。
  • 为什么微信不会出现对方正在输入(原来微信对方正在输入)
  • 2024-11-22原来微信对方正在输入大家好,今天给你们分享一个小妙招每次和朋友微信聊天时,看见他正在输入,是不是很高兴呢?但是有时我们在提示后等很久,对方一个字都没有发出来;究竟是怎么回事呢?我们一起来看看吧!(1)正在输入......。
  • 安卓手机使用时易发热怎么办?(怎么解决手机使用时发热)
  • 2024-11-22怎么解决手机使用时发热保证散热,建议尽量避免边充电边使用手机,充电时尽量避免将手机放置在被子、毯子等散热不好的地方尽量避免使用散热性不好的保护壳,或者在温度升高时去掉手机保护壳等不利于机身散热的物体建议尽量避免手机处在户外。
  • 印度 白虎 豆瓣(印度禁忌电影白虎)
  • 2024-11-22印度禁忌电影白虎印度片,首先第一印象肯定是说着说着台词,演着演着剧情,突然就来一段铛铛呛的音乐,左摇右摆的尬舞,即使那些很有名的宝莱坞电影,也离不开这些元素但如果印度片不尬舞,你还习惯吗?我可不仅习惯,简直很开心,之。