使用 procps-ng 在终端中监控您的 Linux 系统

如何查找程序的进程 ID (PID)。最常见的 Linux 工具由此 procps-ng 软件包提供,包括 ps 和 pstree、pidof 和 pgrep 命令。
71 位读者喜欢这个。
System monitor

图片 CC BY-SA Opensource.com

POSIX 术语中,进程是由操作系统内核管理的正在进行的事件。当您启动应用程序时,会生成一个进程,尽管您的计算机后台运行着许多其他进程,包括保持系统时间准确、监控新文件系统、索引文件等的程序。

大多数操作系统都有某种系统活动监视器,因此您可以了解在任何给定时刻正在运行哪些进程。Linux 有一些可供您选择,包括 GNOME 系统监视器和 KSysGuard。两者都是桌面上的有用应用程序,但 Linux 还提供了在终端中监视系统的能力。无论您选择哪种方式,对于那些积极参与管理计算机的人来说,检查特定进程是一项常见的任务。

在本文中,我将演示如何查找程序的进程 ID (PID)。为此最常用的工具是由 procps-ng 软件包提供的,包括 pspstreepidofpgrep 命令。

查找正在运行的程序的 PID

有时您想获取已知正在运行的特定应用程序的进程 ID (PID)。pidofpgrep 命令通过命令名称查找进程。

pidof 命令返回命令的 PID,按名称搜索确切的命令

$ pidof bash 
1776 5736

pgrep 命令允许使用正则表达式 (regex)

$ pgrep .sh
1605
1679
1688
1776
2333
5736
$ pgrep bash
5736

通过文件查找 PID

您可以使用 fuser 命令使用特定文件查找进程的 PID。

$ fuser --user ~/example.txt                    
/home/tux/example.txt:  3234(tux)

通过 PID 获取进程名称

如果您有进程的 PID数字,但没有生成它的命令,您可以使用 ps 进行“反向查找”

$ ps 3234
 PID TTY      STAT   TIME COMMAND
5736 pts/1    Ss     0:00 emacs

列出所有进程

ps 命令列出进程。您可以使用 -e 选项列出系统上的每个进程

$ ps -e | less
PID TTY          TIME CMD
  1 ?        00:00:03 systemd
  2 ?        00:00:00 kthreadd
  3 ?        00:00:00 rcu_gp
  4 ?        00:00:00 rcu_par_gp
  6 ?        00:00:00 kworker/0:0H-events_highpri
[...]
5648 ?        00:00:00 gnome-control-c
5656 ?        00:00:00 gnome-terminal-
5736 pts/1    00:00:00 bash
5791 pts/1    00:00:00 ps
5792 pts/1    00:00:00 less
(END)

仅列出您的进程

ps -e 的输出可能非常庞大,因此请使用 -U 仅查看一个用户的进程

$ ps -U tux | less
 PID TTY          TIME CMD
3545 ?        00:00:00 systemd
3548 ?        00:00:00 (sd-pam)
3566 ?        00:00:18 pulseaudio
3570 ?        00:00:00 gnome-keyring-d
3583 ?        00:00:00 dbus-daemon
3589 tty2     00:00:00 gdm-wayland-ses
3592 tty2     00:00:00 gnome-session-b
3613 ?        00:00:00 gvfsd
3618 ?        00:00:00 gvfsd-fuse
3665 tty2     00:01:03 gnome-shell
[...]

这将产生少 200 个(上下浮动一百个,具体取决于您运行它的系统)需要筛选的进程。

您可以使用 pstree 命令以不同的格式查看相同的输出

$ pstree -U tux -u --show-pids
[...]
├─gvfsd-metadata(3921)─┬─{gvfsd-metadata}(3923)
│                      └─{gvfsd-metadata}(3924)
├─ibus-portal(3836)─┬─{ibus-portal}(3840)
│                   └─{ibus-portal}(3842)
├─obexd(5214)
├─pulseaudio(3566)─┬─{pulseaudio}(3640)
│                  ├─{pulseaudio}(3649)
│                  └─{pulseaudio}(5258)
├─tracker-store(4150)─┬─{tracker-store}(4153)
│                     ├─{tracker-store}(4154)
│                     ├─{tracker-store}(4157)
│                     └─{tracker-store}(4178)
└─xdg-permission-(3847)─┬─{xdg-permission-}(3848)
			└─{xdg-permission-}(3850)

仅列出带有上下文的您的进程

您可以使用 -u 选项查看您拥有的所有进程的额外上下文。

$ ps -U tux -u
USER  PID %CPU %MEM    VSZ   RSS TTY STAT START  TIME COMMAND
tux  3545  0.0  0.0  89656  9708 ?   Ss   13:59  0:00 /usr/lib/systemd/systemd --user
tux  3548  0.0  0.0 171416  5288 ?   S    13:59  0:00 (sd-pam)
tux  3566  0.9  0.1 1722212 17352 ?  S<sl 13:59  0:29 /usr/bin/pulseaudio [...]
tux  3570  0.0  0.0 664736  8036 ?   SLl  13:59  0:00 /usr/bin/gnome-keyring-daemon [...]
[...]
tux  5736  0.0  0.0 235628  6036 pts/1 Ss 14:18  0:00 bash
tux  6227  0.0  0.4 2816872 74512 tty2 Sl+14:30  0:00 /opt/firefox/firefox-bin [...]
tux  6660  0.0  0.0 268524  3996 pts/1 R+ 14:50  0:00 ps -U tux -u
tux  6661  0.0  0.0 219468  2460 pts/1 S+ 14:50  0:00 less

使用 PID 进行故障排除

如果您在特定应用程序方面遇到问题,或者您只是好奇系统上的应用程序还使用了什么,您可以使用 pmap 查看正在运行的进程的内存映射

$ pmap 1776
5736:   bash
000055f9060ec000   1056K r-x-- bash
000055f9063f3000     16K r---- bash
000055f906400000     40K rw---   [ anon ]
00007faf0fa67000   9040K r--s- passwd
00007faf1033b000     40K r-x-- libnss_sss.so.2
00007faf10345000   2044K ----- libnss_sss.so.2
00007faf10545000      4K rw--- libnss_sss.so.2
00007faf10546000 212692K r---- locale-archive
00007faf1d4fb000   1776K r-x-- libc-2.28.so
00007faf1d6b7000   2044K ----- libc-2.28.so
00007faf1d8ba000      8K rw--- libc-2.28.so
[...]

进程 ID

procps-ng 软件包包含您需要的所有命令,用于调查和监控您的系统在任何时刻正在使用的内容。无论您只是好奇 Linux 系统的所有不同部分如何组合在一起,还是您正在调查错误,或者您正在寻求优化计算机的性能,学习这些命令都会为您理解您的操作系统带来显着的优势。

接下来阅读什么
标签
Seth Kenlon
Seth Kenlon 是一位 UNIX 极客、自由文化倡导者、独立多媒体艺术家和 D&D 爱好者。他曾在电影和计算机行业工作,经常同时进行。

1 条评论

我使用 PID 的目的是为了杀死一些失控的进程。

Creative Commons License本作品根据 Creative Commons Attribution-Share Alike 4.0 International License 许可。
© 2025 open-source.net.cn. All rights reserved.