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端的低占用和高效率运行。