Linux 中查看进程及资源使用情况

简介: Linux 中查看进程及资源使用情况自带的 top 命令类似于平时我们使用的任务管理器,能够列出当前系统中的进程及资源的使用情况。$ man top top - display Linux tasks使用起来很简单,不加任何参数的情况下已经很实用了。

Linux 中查看进程及资源使用情况
自带的 top 命令类似于平时我们使用的任务管理器,能够列出当前系统中的进程及资源的使用情况。

$ man top

   top - display Linux tasks

使用起来很简单,不加任何参数的情况下已经很实用了。其输出大致是下面这个样子:

top命令的输出界面
top命令的输出界面

按 q 可退出该界面。

Tips: top 的输出每 3 秒刷新一次,如果想将画面定格,Mac 下可使用 control + s 来停止刷新,control + q 恢复刷新。当然,还可以通过在当前界面按 d 来设置刷新频率,如下图。

按 d 设置刷新频率
按 d 设置刷新频率

下面来细看各部分的内容的含义。

top
关于机器运行的统计信息。从至依次是:

22:23:10 系统当前时间。
up 80 days, 11:44 系统已经运行了80多天了。
1 user 当前登录的用户数。1 个,也就是我自己。
load average: 1.31, 1.33, 1.29 系统平均负荷(Load),三个值,分别表示过去 1 分钟,5 分钟和 15 分钟的平均负荷。
Tasks
进程统计信息,分别是:

66 total 总计 66 个进程。
1 running 其中 1 个正在运行。
65 sleeping 65 个处于休眠。
0 stopped 0 个停止。
0 zombie 以及 0 个僵尸进程。
这里,其他都好理解,什么又是僵尸进程?简单理解它是这么种进程,任务已经完成但没有退出,仍然显示在进程列表中。常见的情形是子进程,子进程中任务完成后,主进程还可能保持与其进行通信等。继续了解可阅读 What is Zombie Process in Linux?。

CPU
这一行是 CPU 使用情况的统计。分成了 8 个部分,他们相加后当然应该是 100% 啦。

100.0 us :(user) 用户消耗的 CPU 百分比。
0.0 sy :(system) 系统消耗的 CPU。
0.0 ni : nice 进程消耗的 CPU。
0.0 id :(idle) 空闲的 CPU。
0.0 wa :(waiting) 等待处理 I/O 操作的 CPU 资源。
0.0 hi :(Hardware IRQ)处理硬件交互的 CPU 资源。
0.0 si :(Software Interrupts)处理软件交互的 CPU 资源。
0.0 st :(Steal Time)如果当前处于虚拟系统(vm)中,此项表示由管理程序从此系统偷走拿去处理其他任务的 CPU 资源。
其他好说,什么是 nice 进程。简单理解,进程的 nice 值与 priority 都是标识进程优先级的,前者是用户层面的优先级,后者是 Linux Kernel 使用的值。继续了解可移步 Process 'niceness' vs. 'priority'。

Mem & Swap
这两行表示物理内存(RAM)及 swap 空间的使用情况。拿内存这一行来说,依次表示:

606704 total 总内存
89464 free 空闲的部分
128300 used 使用的部分
388940 buff/cache buff 或缓存的部分
关于内存这部分,可阅读此文章 Linux memory management 进一步了解详情。
关于 swap 的理解可阅读 All about Linux swap space。

进程列表
紧接着列出的是各进程,默认以 CPU 使用量排序。

PID: 进程的 id,通过它来操作指定进程。
USER: 进程的所有者。
PR: 进程的优先级。
NI: 进程的 NICE 值,默认 0。
VIRT: 进程使用的虚拟内存。
RES: 进程使用的物理内存。
SHR: 进程使用的共享内存。
S: status,进程的状态: S=睡眠中/sleep R=支行中/running Z=僵尸进程/zombie (S)。
%CPU: 进程消耗的 CPU 百分比。
%MEM: 进程使用的 RAM 百分比。
TIME+: 进程运行时长。
COMMAND: 进程名。
以上。

大致了解后便不会感到眼花缭乱了。对于各指标含义了解后,可方便我们在服务端排查问题,分析程序运行是否可控和正常。比如你的 Node.js 服务。

一些 top 命令
除了展现信息,在 top 的输出界面,还有很多命令可用,比如上面提到的 d 设置刷新时间。

最常用的,发现某个进程快把机器爆掉了,按 k 然后输入其 PID 将该进程结束掉。
o 调整各列的顺序/order。
u 展示某个用户的进程。再次进入设置时设置成空则回到展示全部进程。
z 高亮运行中的进程。
c 展示进程的绝对路径。
htop
除了自带的 top 命令,还可安装另外一个加强版 htop,其界面更加美观,呈现的东西大同小异,但功能交互上更加方便强大。

$ htop
htop 的界面界面

界面上友好的菜单已经无须多说便能上手。
原文地址https://www.cnblogs.com/Wayou/p/linux_top_command.html

相关文章
|
7天前
|
Java Linux
Springboot 解决linux服务器下获取不到项目Resources下资源
Springboot 解决linux服务器下获取不到项目Resources下资源
|
15天前
|
存储 传感器 运维
linux系统资源统计工具
【4月更文挑战第1天】Linux系统监控工具如dstat、htop、glances、vmstat、top、iostat、mpstat、sar和atop,用于跟踪CPU、内存、磁盘I/O、网络和进程性能。这些工具提供实时、交互式和历史数据分析,助力管理员优化系统性能和故障排查。例如,dstat是vmstat等工具的增强版,htop提供彩色界面的进程管理,而atop则结合了多种功能并记录历史数据。
26 5
linux系统资源统计工具
|
4天前
|
算法 Linux 调度
深度解析:Linux内核的进程调度机制
【4月更文挑战第12天】 在多任务操作系统如Linux中,进程调度机制是系统的核心组成部分之一,它决定了处理器资源如何分配给多个竞争的进程。本文深入探讨了Linux内核中的进程调度策略和相关算法,包括其设计哲学、实现原理及对系统性能的影响。通过分析进程调度器的工作原理,我们能够理解操作系统如何平衡效率、公平性和响应性,进而优化系统表现和用户体验。
14 3
|
9天前
|
监控 Linux Shell
初识Linux下进程2
初识Linux下进程2
|
9天前
|
Linux 编译器 Windows
【Linux】10. 进程地址空间
【Linux】10. 进程地址空间
19 4
|
13天前
|
Web App开发 人工智能 Ubuntu
【Linux】Linux启动/查看/结束进程命令(详细讲解)
【Linux】Linux启动/查看/结束进程命令(详细讲解)
|
19天前
|
Linux Shell 调度
【Linux】进程排队的理解&&进程状态的表述&&僵尸进程和孤儿进程的理解
【Linux】进程排队的理解&&进程状态的表述&&僵尸进程和孤儿进程的理解
|
20天前
|
监控 Linux Shell
Linux 进程问题调查探秘:分析和排查频繁创建进程问题
Linux 进程问题调查探秘:分析和排查频繁创建进程问题
39 0
|
20天前
|
存储 Linux 程序员
【Linux C/C++ 堆内存分布】深入理解Linux进程的堆空间管理
【Linux C/C++ 堆内存分布】深入理解Linux进程的堆空间管理
66 0
|
20天前
|
消息中间件 存储 网络协议
Linux IPC 进程间通讯方式的深入对比与分析和权衡
Linux IPC 进程间通讯方式的深入对比与分析和权衡
65 0