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天前
|
NoSQL Linux 程序员
【linux进程信号(一)】信号的概念以及产生信号的方式
【linux进程信号(一)】信号的概念以及产生信号的方式
|
1天前
|
Linux
【linux进程间通信(一)】匿名管道和命名管道
【linux进程间通信(一)】匿名管道和命名管道
|
1天前
|
Java Shell Linux
【linux进程控制(三)】进程程序替换--如何自己实现一个bash解释器?
【linux进程控制(三)】进程程序替换--如何自己实现一个bash解释器?
|
1天前
|
算法 Linux Shell
【linux进程(二)】如何创建子进程?--fork函数深度剖析
【linux进程(二)】如何创建子进程?--fork函数深度剖析
|
1天前
|
存储 Linux Shell
【linux进程(一)】深入理解进程概念--什么是进程?PCB的底层是什么?
【linux进程(一)】深入理解进程概念--什么是进程?PCB的底层是什么?
|
2天前
|
消息中间件 Unix Linux
Linux的学习之路:17、进程间通信(1)
Linux的学习之路:17、进程间通信(1)
17 1
|
3天前
|
存储 安全 Linux
Linux的学习之路:9、冯诺依曼与进程(1)
Linux的学习之路:9、冯诺依曼与进程(1)
18 0
|
8天前
|
算法 Linux 调度
深入理解Linux内核的进程调度机制
【4月更文挑战第17天】在多任务操作系统中,进程调度是核心功能之一,它决定了处理机资源的分配。本文旨在剖析Linux操作系统内核的进程调度机制,详细讨论其调度策略、调度算法及实现原理,并探讨了其对系统性能的影响。通过分析CFS(完全公平调度器)和实时调度策略,揭示了Linux如何在保证响应速度与公平性之间取得平衡。文章还将评估最新的调度技术趋势,如容器化和云计算环境下的调度优化。
|
9天前
|
监控 Linux
linux监控指定进程
请注意,以上步骤提供了一种基本的方式来监控指定进程。根据你的需求,你可以选择使用不同的工具和参数来获取更详细的进程信息。
14 0
|
1月前
|
消息中间件 Linux
Linux进程间通信(IPC)教程 Linux共享内存介绍:介绍POSIX共享内存的基本概念、用途和编程实践
Linux进程间通信(IPC)教程 Linux共享内存介绍:介绍POSIX共享内存的基本概念、用途和编程实践
24 2