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

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

nanshan 2025-02-19 13:14 15 浏览 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端的低占用和高效率运行。

相关推荐

0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)

文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...

ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes

为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...

生产环境starrocks 3.1存算一体集群部署

集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...

在CentOS上添加swap虚拟内存并设置优先级

现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...

国产深度(deepin)操作系统优化指南

1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...

postgresql-15.4 多节点主从(读写分离)

1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...

Docker 容器 Java 服务内存与 GC 优化实施方案

一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...

虚拟内存设置、解决linux内存不够问题

虚拟内存设置(解决linux内存不够情况)背景介绍  Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...

Elasticsearch性能调优(5):服务器配置选择

在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...

Es如何落地

一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...

针对Linux内存管理知识学习总结

现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...

MySQL进阶之性能优化

概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...

Linux Cgroups(Control Groups)原理

LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...

linux 常用性能优化参数及理解

1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...

如何在 Linux 中使用 Sysctl 命令?

sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...

取消回复欢迎 发表评论: