cpu 基本信息
命令
$ lscpu
示例
Architecture: x86_64
CPU op-mode(s): 32-bit, 64-bit
Byte Order: Little Endian
CPU(s): 4
On-line CPU(s) list: 0-3
Thread(s) per core: 1
Core(s) per socket: 1
Socket(s): 4
NUMA node(s): 1
Vendor ID: GenuineIntel
CPU family: 6
Model: 79
Model name: Intel(R) Xeon(R) CPU E5-2650 v4 @ 2.20GHz
Stepping: 1
CPU MHz: 2199.998
BogoMIPS: 4399.99
Hypervisor vendor: VMware
Virtualization type: full
L1d cache: 32K
L1i cache: 32K
L2 cache: 256K
L3 cache: 30720K
NUMA node0 CPU(s): 0-3
TOP 命令
命令
$ top
top - 07:57:03 up 314 days, 22:07, 1 user, load average: 0.78, 0.74, 0.71
Tasks: 185 total, 1 running, 184 sleeping, 0 stopped, 0 zombie
Cpu(s): 25.3%us, 0.2%sy, 0.0%ni, 74.5%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st
Mem: 3924152k total, 3654960k used, 269192k free, 298772k buffers
Swap: 8388604k total, 11580k used, 8377024k free, 1705120k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
5035 ryo 20 0 5261m 1.2g 6468 S 101.1 30.9 444:48.63 java
27085 ryo 20 0 797m 109m 4188 S 0.3 2.9 368:07.60 filebeat
字段解释
VIRT:virtual memory usage 虚拟内存
-
进程“需要的”虚拟内存大小,包括进程使用的库、代码、数据等
-
假如进程申请100m的内存,但实际只使用了10m,那么它会增长100m,而不是实际的使用量
RES:resident memory usage 常驻内存
-
进程当前使用的内存大小,但不包括swap out
-
包含其他进程的共享
-
如果申请100m的内存,实际使用10m,它只增长10m,与VIRT相反
-
关于库占用内存的情况,它只统计加载的库文件所占内存大小
SHR:shared memory 共享内存
-
除了自身进程的共享内存,也包括其他进程的共享内存
-
虽然进程只使用了几个共享库的函数,但它包含了整个共享库的大小
-
计算某个进程所占的物理内存大小公式:RES – SHR
-
swap out后,它将会降下来
DATA
-
数据占用的内存。如果top没有显示,按f键可以显示出来。
-
真正的该程序要求的数据空间,是真正在运行中要使用的。
top 运行显示的调整
top 运行中可以通过 top 的内部命令对进程的显示方式进行控制。
内部命令
如下:
s – 改变画面更新频率
l – 关闭或开启第一部分第一行 top 信息的表示
t – 关闭或开启第一部分第二行 Tasks 和第三行 Cpus 信息的表示
m – 关闭或开启第一部分第四行 Mem 和 第五行 Swap 信息的表示
N – 以 PID 的大小的顺序排列表示进程列表
P – 以 CPU 占用率大小的顺序排列进程列表
M – 以内存占用率大小的顺序排列进程列表
h – 显示帮助
n – 设置在进程列表所显示进程的数量
q – 退出 top
s – 改变画面更新周期
属性含义
序号 列名 含义
a PID 进程id
b PPID 父进程id
c RUSER Real user name
d UID 进程所有者的用户id
e USER 进程所有者的用户名
f GROUP 进程所有者的组名
g TTY 启动进程的终端名。不是从终端启动的进程则显示为 ?
h PR 优先级
i NI nice值。负值表示高优先级,正值表示低优先级
j P 最后使用的CPU,仅在多CPU环境下有意义
k %CPU 上次更新到现在的CPU时间占用百分比
l TIME 进程使用的CPU时间总计,单位秒
m TIME+ 进程使用的CPU时间总计,单位1/100秒
n %MEM 进程使用的物理内存百分比
o VIRT 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
p SWAP 进程使用的虚拟内存中,被换出的大小,单位kb。
q RES 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
r CODE 可执行代码占用的物理内存大小,单位kb
s DATA 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb
t SHR 共享内存大小,单位kb
u nFLT 页面错误次数
v nDRT 最后一次写入到现在,被修改过的页面数。
w S 进程状态。(D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程)
x COMMAND 命令名/命令行
y WCHAN 若该进程在睡眠,则显示睡眠中的系统函数名
z Flags 任务标志,参考 sched.h
默认情况下仅显示比较重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列。
更改显示内容
可以通过下面的快捷键来更改显示内容。
通过 f 键可以选择显示的内容。
按 f 键之后会显示列的列表,按 a-z 即可显示或隐藏对应的列,最后按回车键确定。
按 o 键可以改变列的显示顺序。
按小写的 a-z 可以将相应的列向右移动,而大写的 A-Z 可以将相应的列向左移动。最后按回车键确定。
按大写的 F 或 O 键,然后按 a-z 可以将进程按照相应的列进行排序。而大写的 R 键可以将当前的排序倒转。
top使用方法:
使用格式:
top [-] [d] [p] [q] [c] [C] [S] [s] [n]
参数说明:
d:指定每两次屏幕信息刷新之间的时间间隔。当然用户可以使用s交互命令来改变之。
p: 通过指定监控进程ID来仅仅监控某个进程的状态。
q: 该选项将使top没有任何延迟的进行刷新。如果调用程序有超级用户权限,那么top将以尽可能高的优先级运行。
S:指定累计模式。
s:使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险。
i:使top不显示任何闲置或者僵死进程。
c: 显示整个命令行而不只是显示命令名。
常用命令说明:
Ctrl+L:擦除并且重写屏幕
K:终止一个进程。系统将提示用户输入需要终止的进程PID,以及需要发送给该进程什么样的信号。一般的终止进程可以使用15信号;如果不能正常结束那就使用信号9强制结束该进程。默认值是信号15。在安全模式中此命令被屏蔽。
i:忽略闲置和僵死进程。这是一个开关式命令。
q:退出程序
r: 重新安排一个进程的优先级别。系统提示用户输入需要改变的进程PID以及需要设置的进程优先级值。输入一个正值将使优先级降低,反之则可以使该进程拥有更高的优先权。默认值是10。
S:切换到累计模式。
s:改变两次刷新之间的延迟时间。系统将提示用户输入新的时间,单位为s。如果有小数,就换算成m s。输入0值则系统将不断刷新,默认值是5 s。需要注意的是如果设置太小的时间,很可能会引起不断刷新,从而根本来不及看清显示的情况,而且系统负载也会大大增加。
f或者F:从当前显示中添加或者删除项目。
o或者O:改变显示项目的顺序
l:切换显示平均负载和启动时间信息。
m: 切换显示内存信息。
t: 切换显示进程和CPU状态信息。
c:切换显示命令名称和完整命令行。
M: 根据驻留内存大小进行排序。
P: 根据CPU使用百分比大小进行排序。
T: 根据时间/累计时间进行排序。
W: 将当前设置写入~/.toprc文件中。
chat
Q1-详细介绍一下 top 命令
top
命令是一个用于实时监视系统性能的命令行工具。
它提供了有关运行中的进程、系统资源使用情况以及其他系统性能指标的实时信息。
以下是top
命令的详细介绍:
命令格式:
top
主要输出信息:
top
命令的输出信息主要包括以下几个部分:
- 系统总体信息:
- 系统时间。
- 运行时间。
- 登录用户数。
- 系统负载(1分钟、5分钟和15分钟的负载平均值)。
- 进程信息:
- 进程总数。
- 运行中的进程数。
- 睡眠中的进程数。
- 僵尸进程数。
- CPU信息:
- 用户空间使用的CPU百分比。
- 系统内核使用的CPU百分比。
- 空闲CPU百分比。
- 等待I/O的CPU百分比。
- 硬中断和软中断的CPU百分比。
- 内存信息:
- 总物理内存。
- 已用内存。
- 空闲内存。
- 缓存使用情况。
- 交换空间使用情况。
- 进程列表:
- 列出当前运行的进程,并显示其PID(进程ID)、用户、CPU使用百分比、内存使用百分比、进程状态等信息。
- 默认按照CPU使用百分比排序,可以通过按键切换排序方式。
常用交互命令:
- q:退出
top
。 - Space:刷新
top
显示。 - k:终止进程,输入PID后按回车。
- u:显示指定用户的进程。
- M:按内存使用百分比排序进程。
- P:按CPU使用百分比排序进程。
示例:
top
输出解释:
top
的输出信息非常丰富,提供了对系统性能的全面监视。
你可以通过观察进程列表、CPU使用情况、内存使用情况等来诊断系统性能问题,并及时采取措施。
Q2-实际例子
top
效果如下:
$ top
top - 09:28:32 up 1:28, 1 user, load average: 0.00, 0.00, 0.00
Tasks: 34 total, 1 running, 32 sleeping, 1 stopped, 0 zombie
%Cpu(s): 0.0 us, 0.0 sy, 0.0 ni,100.0 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
MiB Mem : 7808.3 total, 6318.6 free, 516.2 used, 973.4 buff/cache
MiB Swap: 2048.0 total, 2048.0 free, 0.0 used. 7061.6 avail Mem
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
1127 root 20 0 771140 82952 22408 S 0.0 1.0 0:03.00 python3.10
143 root 20 0 1836144 55612 18172 S 0.0 0.7 0:06.68 snapd
1131 root 20 0 44208 37692 10248 S 0.3 0.5 0:02.72 python3
204 root 20 0 107216 21256 13088 S 0.0 0.3 0:00.02 unattended-upgr
140 root 20 0 30124 18596 9984 S 0.0 0.2 0:00.03 networkd-dispat
38 root 19 -1 47808 15172 14156 S 0.0 0.2 0:00.09 systemd-journal
1 root 20 0 167024 12556 8344 S 0.0 0.2 0:00.73 systemd
121 systemd+ 20 0 25260 12424 8488 S 0.0 0.2 0:00.06 systemd-resolve
377 dh 20 0 16936 9012 7676 S 0.0 0.1 0:00.03 systemd
151 root 20 0 15324 7388 6448 S 0.0 0.1 0:00.07 systemd-logind
62 root 20 0 21932 5812 4448 S 0.0 0.1 0:00.13 systemd-udevd
339 dh 20 0 6080 5108 3384 S 0.0 0.1 0:00.15 bash
142 syslog 20 0 222400 5072 4508 S 0.0 0.1 0:00.02 rsyslogd
407 dh 20 0 6068 5032 3380 S 0.0 0.1 0:00.01 bash
340 root 20 0 7520 4880 3968 S 0.0 0.1 0:00.00 login
133 message+ 20 0 8584 4548 3968 S 0.0 0.1 0:00.11 dbus-daemon
1295 dh 20 0 7812 3688 3088 R 0.7 0.0 0:00.03 top 1294 dh 20 0 7812 3580 2980 T 0.0 0.0 0:00.01 top
392 dh 20 0 168752 3364 16 S 0.0 0.0 0:00.00 (sd-pam)
1105 root 20 0 4780 3288 3040 S 0.0 0.0 0:00.03 subiquity-serve
131 root 20 0 4304 2652 2404 S 0.0 0.0 0:00.00 cron
75 root 20 0 4784 1772 1332 S 0.0 0.0 0:00.62 snapfuse
79 root 20 0 4712 1728 1228 S 0.0 0.0 0:02.27 snapfuse
1031 root 20 0 4960 1692 1200 S 0.0 0.0 0:00.75 snapfuse
850 root 20 0 4848 1636 1168 S 0.0 0.0 0:00.62 snapfuse
82 root 20 0 4768 1612 1144 S 0.0 0.0 0:00.67 snapfuse
2 root 20 0 2324 1188 1084 S 0.0 0.0 0:00.00 init-systemd(Ub
201 root 20 0 3236 1068 984 S 0.0 0.0 0:00.00 agetty
linux 如何查看机器的 cpu 压力?
在Linux系统上,你可以使用多种工具来查看机器的CPU压力。
以下是一些常用的方法:
-
top命令: 打开终端并输入
top
,可以查看实时的系统状态信息,包括CPU使用情况、内存使用情况等。在top界面,CPU相关的信息会显示在顶部,包括CPU利用率、进程信息等。按下键盘上的q
可以退出。top
-
htop命令:
htop
是一个更先进的交互式系统监视器,提供了比top更多的功能和更友好的用户界面。你可以使用包管理工具安装htop,例如在Ubuntu上:sudo apt-get install htop
安装完成后,输入
htop
即可打开htop。 -
mpstat命令:
mpstat
用于显示多处理器系统的统计信息,包括每个处理器的使用情况。以下是一个示例:mpstat
你也可以指定采样的时间间隔和次数,例如:
mpstat 5 3
上述命令将每5秒输出一次统计信息,共输出3次。
-
sar命令:
sar
命令用于收集、报告和保存系统活动信息,包括CPU利用率。你可以使用以下命令:sar
若要查看特定时间段的CPU使用情况,可以使用
-s
选项,例如:sar -u -s 10:00:00 -e 10:05:00
这些工具都可以帮助你监视系统的CPU使用情况,选择其中一个或多个根据你的需求进行使用。
如何查看 linux 是几核的?
要查看Linux系统有几个CPU核心,可以使用以下几种方法:
-
lscpu命令:
lscpu
命令可以显示有关CPU架构和其他详细信息,包括核心数。lscpu
输出中的 “Core(s) per socket” 行表示每个物理CPU插槽中的核心数,而 “Socket(s)” 行表示系统中的物理CPU插槽数。
-
/proc/cpuinfo文件:
/proc/cpuinfo
文件包含有关CPU的信息,包括核心数量。可以使用grep
命令来筛选核心相关的信息:grep -E '^processor|^physical id|^core id' /proc/cpuinfo | sort -u
上述命令将输出每个处理器的编号、物理ID和核心ID,并通过
sort -u
去重。 -
nproc命令:
nproc
命令用于显示系统上的CPU核心数量。nproc
该命令会直接输出CPU核心数。
这些方法中,lscpu
通常是最简单和最直观的方式来查看CPU核心数。
选择其中一种方法根据你的需要进行查看。
如果是一个 8 核的 cpu,top 时一个进程占用 %CPU 50%,是什么意思?
当在top命令中看到一个进程占用 %CPU 50%,表示该进程正在使用系统的CPU资源,而且它正在使用整个系统CPU的一半。
这通常是相对于单个CPU核心的百分比。
对于一个8核的CPU,每个核心的最大使用率是100%,因此50%表示该进程正在使用系统中一个核心的一半的计算能力。
对于一个8核CPU,50%的CPU使用率可能是由于该进程在一个核心上占用50%,而其他7个核心处于空闲状态。这也可能是由于该进程在多个核心上以平均的方式分配了计算任务,从而导致整个系统CPU使用率的50%。
在多核系统中,系统总的CPU使用率是所有核心使用率的总和。
因此,如果有多个进程占用CPU,系统的总使用率可能会超过100%。
这是因为每个进程都可以在不同的核心上运行,使得它们的使用率相加超过100%。