百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

CentOS7.2的top命令CPU不匹配?_top命令 vsz

nanshan 2025-02-19 13:14 9 浏览 0 评论

CentOS7.2 又瞬间看不懂了;CPU核心占用和进程占用为什么不匹配!

给了4个核的CPU,下方进程第一个占用50.3%,应该是400%里的50.3%,

第二个占用36.8%...全部加起来有240%多一点,但是为什么上面4个%CPU核心占用显示的才2.2%,0.4%,0.0%,4.0%?

而且每个CPU的idle都是99%左右。

所以下方进程的CPU百分比到底是什么意思?

————————————————

上面算是向专业人士求个助。

下面对这幅图做一个科普,顺带给自己复习和总结一下学透没有。

————————————————

CeotOS是Linux的一个发行版,

说重点它就是一个免费的操作系统,但不适合个人用户玩耍

跟微软的Windows比起来,

Linux更稳定,适合长期开机做服务器;

Windows需要定期重启否则经常会变得卡顿,难以操作。

Linux作为服务器通常会关闭窗口图形界面,用黑底白字的“命令行”来操作;

Windows以图形为主,windows就是指的一个个的窗口,就是对用户友好的图形界面。

Linux上无法运行大多数游戏、娱乐软件,所以不适合个人玩耍,但可以办公;

Windows面向大众,几乎所有的游戏、娱乐乃至办公软件都兼容,且对显卡支持特别好

Windows也有服务器版,不过仍然很臃肿,比不过Linux的精简和稳定。

—————————————————

Linux中有很多常见命令,其中 top 就是一个。

Linux 的 top 命令相当于 Windows 中在任务栏点右键点选的“任务管理器”,并且会实时更新

下面来解读一下这个表,懂的当复习,不懂的一起来学习

(一)系统资源总体使用状况

第一行:top - 09:26:57 up 8 days, 14:56 3 users, load average: 0.61, 0.47, 0.50

top 表示这个命令叫 top;

09:09:29 表示当前时间(这里没有显示日期);

up 8 days, 14:38 表示系统已经开机 8 天 14 小时 38 分钟了;

3 users, 表示目前这个系统有不同的人在 3 个地方同时登录:

一个就是我在本机PC通过Xshell登录,登录方式是 pts/0

一个应该是在虚拟机上本地本机的登录,登录方式是 tty1

./还有一个我也不太清楚,用 w 命令和 who 命令都只能看到两个。求解答

load average: 0.19, 0.50, 0.48 表示在过去1分钟、5分钟和15分钟内的平均CPU负载;

第二行:Tasks:172 total, 1running, 170 sleeping, 0 stopped, 1 zombie

Tasks:当前内存中进程总数

running:正在运行的进行数

sleeping:正在休眠的进程(在内存但是没有使用,要用的时候需要叫醒)

stopped:停止的进程(不知道啥意思)

zombie:僵尸进程(某个子进程已经执行exit退出了执行,父进程却还没有给他“收尸”)

第三~六行:(按 1 键)%Cpu : 2.2 us, 0.7 sy, 0.0 ni, 97.0 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st

%Cpu:CPU的占用百分比

us:user,表示没有被修改过NICE(优先权)值的进程占用CPU百分比

sy:system,操作系统核心进程占用CPU百分比

ni:nice,修改过NICE值的进程占用百分比(NICE值一会儿专门说说)

id:idle,空闲的CPU百分数

wa:IO-wait,等待硬盘写入(硬盘很慢)的进程占用CPU百分数

hi:hardware interrupt 硬件外围设备发给操作系统内核中断当前任务,来执行我的

si:software interrupt 软件通知CPU中断执行当前任务,来执行我的

P.S. NICE值(高尚,无私)

每个进程都有一个PRI和NICE值;

PRI就是任务执行的优先权,-20到+19,数值越大,执行优先权越小(就越高尚,主动让别人先执行,Ladies First,I'm after you.)

NICE 就是对这个PRI的修改。所有的优先权都继承于 init,所有都是0,编程或者运行的时候可以手动修改这个值,改变执行优先权。

关于这个我就知道这么多,可能还有一些错误,请各位多读书。

下一行:KiB Mem: 3861288 total, 140524 free, 2960864 used, 759900 buff/cache

以 KB 表示的内存用量

linux的内存管理普通人就很难理解了,这个内存占用和windows的含义完全不一样,按照字面意思,140524 free 就是说只有140MB的内存是空闲,如果现在的win10只有140MB空闲,系统就快崩溃了。所以只能从字面上解释一下了。

Mem: 3861288 total 3,861,288 KiB 总内存(总计4GB物理内存)

140524 free 140MB未使用

2960864 used 2,960,864 KiB内存使用中(2.96GB内存使用中)

759900 buff/cache 759,900 KiB内存作为缓存(759.9MiB内存已缓存,这个无法理解)

下一行:KiB Swap 和上一行类似,Swap 就是把硬盘上的一部分当做内存用,就像 windows 的虚拟内存,后面几个含义一样。

(二)往下就是具体进程了。有这几个字段

PID Process ID,进程的唯一数字标志

USER 用户 哪个用户启动的这个进程

PR PRIORITY,执行优先级,数字越大优先级越高

NI NICE,是对PRI优先级的修正,NI的取值范围是-20~19,越大越佛系,越“高尚”

VIRT Virtual Memory(虚拟内存)系统理论上在规划图纸上划给进程的内存量。就像一个地产商在政府那里申请地盘,领导说:A,B,C这三块都归你。但是实际上ABC都还是荒地。但在今后,这位地产老板就可以派施工队去ABC搞建筑而不会在政策层面和别人有冲突。不过在 linux 系统里,这三块地方并不像土地那样很固定,而是动态的,就像是说:给你 3平方千米,这个面积的土地并不是内存条里固定的物理地址,而会根据实际搞建筑的时候蜿蜒扭曲,只要能用到就行了。

RES Resident Memory(驻留内存)上面说了领导在图纸上把 3平方千米的土地给了地产老板,但是老板建筑有进度,今天只开发了1平方千米,于是这1平方千米就是“驻留内存”。

SHR Shared Memory(共享内存)在上面的规划中,如果有两个地产老板,老板A从市领导手里拿到了3平方千米土地,老板B拿到了4平方千米。只要城市面积大于7平方千米,他们分配到的面积就不会冲突。但是,有些公共设施并不需要在两位老板的地盘上各建一个,比如放空警报,它能覆盖半径10千米的地盘,不需要建太多。只需要建一个,并且半径能覆盖两位老板的地盘就可以了。这时候就需要划分一个面积比如0.1平方千米来建这个警报塔。在 linux 中警报塔的0.1平方千米既占了A老板的地盘,又占了B老板的地盘。

这时候,对于两位老板来说,0.1平方千米就是SHR,共享区域。

对于老板A来说,3-0.1=2.9平方千米的地盘就是A老板的独占区域。

对于老板B来说,4-0.1=3.9平方千米的地盘就是B老板的独占区域。

(以上内存解说为全网独家,欢迎转载盗用,请注明作者和头条平台,谢谢)

%CPU(CPU占用百分数)。当前进程在当前时刻占用了多少CPU运算资源。CentOS7.0以后,CPU的满载与核心数挂钩。比如一个4核心的CPU,满载就是400%。也就是一个核满载只算100%。所以这幅图我自己就看不懂了,进程第一名明明占用了50%以上,为何上方CPU才4%左右。

%MEM(内存占用百分数。这个大概意思明白,但我并没有去深挖含义,暂时似乎也不需要,先就这么着。

TIME+ 启动后占用CPU的总时间。这个可有意思了。进程在运行的时候,并不是时刻都需要CPU去运算,而是“空挂在那里等活儿”。空挂着的时候,就不消耗CPU运算时间。看图,数到下面 741:36:69 这个地方(上面四位数的全部不要)这个数字就表示741分钟36.69秒(0.69表示把一秒分成100份)。

COMMAND 进程名称。也叫命令名称。就是这一行是哪一个命令启动的。

------------------------------------------

后记:这幅图是一个“森林龙”手游的服务端资源占用图,从图中可以看出,该服务端系统资源空转浪费严重。一个玩家都没有,居然CPU占用达到如此高的水平。远远比不上dnf neople端的低占用和高效率运行。

相关推荐

电脑cpu占用率高?怎么办?1分钟快速解决!

案例:电脑cup过高怎么办?【我的电脑运行缓慢,导致我学习和工作的效率很低。刚刚查看了一下电脑,发现它的cpu占用率很高。有没有小伙伴知道如何解决此电脑cpu过高的问题?】电脑是我们生活中不可缺少的工...

CPU使用率100%怎么办

当电脑的CPU使用率达到100%时,往往会引发一系列令人头疼的问题,如卡顿、过载、过热甚至死机。这些问题不仅严重影响了电脑的正常使用,还可能对硬件造成损害。为了有效应对这一挑战,我们可以采取一系列措施...

提高CPU利用率方法

一、背景:一般小项目服务器的虚拟机服务器CPU很难达到要求的,要求一般都是使用率达到60%-90%,除非是数据库服务器,还有计算很频繁的应用服务器,不然是大部分的都不能达到要求的,无法达到要求,就得是...

Go到Rust:代码对比揭示60% CPU使用率降低的技术路径

Go与Rust作为现代系统级编程语言,在并发处理和内存管理上采取了截然不同的设计哲学。本文通过四个典型场景的代码对比,剖析两种语言在CPU效率层面的核心差异,揭示为何部分技术团队通过语言迁移实现了60...

一招教你解决CPU占用率100%的问题 #电脑小技巧

大家好,今天讲一下CPU占用率100%的解决方法。·首先点运行,在这块输入gpedit.msc回车。·打开管理模板,Windows组件,MicrosoftDefender防病毒。·点开扫描,扫描期间...

技术丨教你降低CPU与内存占用率,让系统快如闪电

当内存和CPU都达到了较大的占用率时,很可能会导致系统崩溃。该如何解决这一问题?本期视频将指导大家:如何有效减少内存和CPU的占用率。快来看看具体操作步骤吧!1.尝试运行ePSA硬件检测首先,尝试运...

Serv00服务器搭建代理节点全流程|无需保号保活|Cloudflare隧道

注册图文教程(2024)「链接」视频教程BiliBili:Serv00服务器搭建代理节点全流程|无需保号保活|Cloudflare隧道|serv00-play脚本_哔哩哔哩_bilibiliS...

600+ 道 Java面试题及答案整理(建议收藏)

小七整理了最近几年最新、最全的Java面试题,题目涉及Java基础、集合、多线程、IO、分布式、Spring全家桶、MyBatis、Dubbo、缓存、消息队列、Linux…等等。题库共6...

网络编程 | 彻底搞懂网络 IO 模型

令人头大的IO说起网络IO相关的开发,很多人都头大,包括我自己,写了几年的代码,对IO相关的术语说起来也是头头是道,什么NIO、IO多路复用等术语一个接一个。但是也就自己知道,这些概念一...

开源全方位运维监控工具:HertzBeat

HertzBeat:实时监控系统性能,精准预警保障业务稳定-精选真开源,释放新价值。概览HertzBeat是一款深受广大开发者喜爱的开源实时监控解决方案。它以其简洁直观的设计理念和免安装Agent的...

网络安全工程师必知的75个网络端口

作为一名网络安全工程师,必须熟知网络端口,一般将端口分为以下3类:(1)公认端口(Well-KnownPorts):范围从0到1023(2)注册端口(RegisteredPorts):从1024到...

PHP技能评测

公司出了一些自我评测的PHP题目,现将题目和答案记录于此,以方便记忆。1.魔术函数有哪些,分别在什么时候调用?__construct(),类的构造函数__destruct(),类的析构函数__cal...

2020年Dubbo30道高频面试题!还在为面试烦恼赶快来看看

前言Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。简单的说,dubbo就是个服务框架,如果没有分布式的需求,其实是不需要用的,只有在分布式的...

2018年度回顾:挖矿木马为什么会成为病毒木马黑产的中坚力量

一、概述根据腾讯御见威胁情报中心监测数据,2018年挖矿木马样本月产生数量在百万级别,且上半年呈现快速增长趋势,下半年上涨趋势有所减缓。由于挖矿的收益可以通过数字加密货币系统结算,使黑色产业变现链条十...

自查风险突出的30个服务高危端口

在计算机网络中,端口是一种用于区分不同网络服务或应用程序的逻辑地址。每个网络服务或应用程序都需要至少一个端口(号)来实现网络通信。当某个端口开放时,便能接收来自于其它计算机或网络设备的连接请求和数据。...

取消回复欢迎 发表评论: