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

相关文章
|
1月前
|
算法 Linux 调度
深入理解Linux操作系统的进程管理
本文旨在探讨Linux操作系统中的进程管理机制,包括进程的创建、执行、调度和终止等环节。通过对Linux内核中相关模块的分析,揭示其高效的进程管理策略,为开发者提供优化程序性能和资源利用率的参考。
69 1
|
1天前
|
消息中间件 Linux
Linux:进程间通信(共享内存详细讲解以及小项目使用和相关指令、消息队列、信号量)
通过上述讲解和代码示例,您可以理解和实现Linux系统中的进程间通信机制,包括共享内存、消息队列和信号量。这些机制在实际开发中非常重要,能够提高系统的并发处理能力和数据通信效率。希望本文能为您的学习和开发提供实用的指导和帮助。
35 20
|
21天前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
89 13
|
28天前
|
SQL 运维 监控
南大通用GBase 8a MPP Cluster Linux端SQL进程监控工具
南大通用GBase 8a MPP Cluster Linux端SQL进程监控工具
|
1月前
|
运维 监控 Linux
Linux操作系统的守护进程与服务管理深度剖析####
本文作为一篇技术性文章,旨在深入探讨Linux操作系统中守护进程与服务管理的机制、工具及实践策略。不同于传统的摘要概述,本文将以“守护进程的生命周期”为核心线索,串联起Linux服务管理的各个方面,从守护进程的定义与特性出发,逐步深入到Systemd的工作原理、服务单元文件编写、服务状态管理以及故障排查技巧,为读者呈现一幅Linux服务管理的全景图。 ####
|
2月前
|
缓存 算法 Linux
Linux内核的心脏:深入理解进程调度器
本文探讨了Linux操作系统中至关重要的组成部分——进程调度器。通过分析其工作原理、调度算法以及在不同场景下的表现,揭示它是如何高效管理CPU资源,确保系统响应性和公平性的。本文旨在为读者提供一个清晰的视图,了解在多任务环境下,Linux是如何智能地分配处理器时间给各个进程的。
|
2月前
|
存储 运维 监控
深入Linux基础:文件系统与进程管理详解
深入Linux基础:文件系统与进程管理详解
92 8
|
2月前
|
网络协议 Linux 虚拟化
如何在 Linux 系统中查看进程的详细信息?
如何在 Linux 系统中查看进程的详细信息?
192 1
|
2月前
|
Linux
如何在 Linux 系统中查看进程占用的内存?
如何在 Linux 系统中查看进程占用的内存?
|
2月前
|
算法 Linux 定位技术
Linux内核中的进程调度算法解析####
【10月更文挑战第29天】 本文深入剖析了Linux操作系统的心脏——内核中至关重要的组成部分之一,即进程调度机制。不同于传统的摘要概述,我们将通过一段引人入胜的故事线来揭开进程调度算法的神秘面纱,展现其背后的精妙设计与复杂逻辑,让读者仿佛跟随一位虚拟的“进程侦探”,一步步探索Linux如何高效、公平地管理众多进程,确保系统资源的最优分配与利用。 ####
77 4