管理进程的 Linux 命令

一、启动进程

启动进程的最简单方法是在命令行中键入其名称,然后按回车键。如果要启动 Nginx web 服务器,请键入 nginx 。也许您只是想看看其版本。

alan@workstation:~$ nginx -v
nginx version: nginx/1.14.0

二、查看您的可执行路径

以上启动进程的演示是假设可执行文件位于您的可执行路径中。理解这个路径是可靠地启动和管理进程的关键。管理员通常会为他们想要的目的定制这条路径。您可以使用 echo $PATH 查看您的可执行路径。

alan@workstation:~$ echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin

三、WHICH

使用 which 命令查看可执行文件的完整路径。

alan@workstation:~$ which nginx
/opt/nginx/bin/nginx

四、保持进程运行

NOHUP

注销或关闭终端时,进程可能不会继续运行。这种特殊情况可以通过在要使用 nohup 命令放在要运行的命令前面让进程持续运行。此外,附加一个 & 符号将会把进程发送到后台,并允许您继续使用终端。例如,假设您想运行 myprogram.sh

nohup myprogram.sh &
nohup 会返回运行进程的 PID。

五、管理正在运行的进程

每个进程都有一个唯一的进程标识号 (PID) 。这个数字是我们用来管理每个进程的。我们还可以使用进程名称,我将在下面演示。有几个命令可以检查正在运行的进程的状态。让我们快速看看这些命令。

1、PS
最常见的是 ps 命令。ps 的默认输出是当前终端中运行的进程的简单列表。如下所示,第一列包含 PID。

alan@workstation:~$ ps
PID TTY          TIME  CMD
23989 pts/0    00:00:00 bash
24148 pts/0    00:00:00 ps

我想看看我之前启动的 Nginx 进程。为此,我告诉 ps 给我展示每一个正在运行的进程(-e)和完整的列表(-f)。

alan@workstation:~$ ps -ef
UID        PID  PPID  C STIME TTY          TIME CMD
root         1     0  0Aug18?        00:00:10/sbin/init splash
root         2     0  0Aug18?        00:00:00[kthreadd]
root         4     2  0Aug18?        00:00:00[kworker/0:0H]
root         6     2  0Aug18?        00:00:00[mm_percpu_wq]
root         7     2  0Aug18?        00:00:00[ksoftirqd/0]
root         8     2  0Aug18?        00:00:20[rcu_sched]
root         9     2  0Aug18?        00:00:00[rcu_bh]
root        10     2  0Aug18?        00:00:00[migration/0]
root        11     2  0Aug18?        00:00:00[watchdog/0]
root        12     2  0Aug18?        00:00:00[cpuhp/0]
root        13     2  0Aug18?        00:00:00[cpuhp/1]
root        14     2  0Aug18?        00:00:00[watchdog/1]
root        15     2  0Aug18?        00:00:00[migration/1]
root        16     2  0Aug18?        00:00:00[ksoftirqd/1]
alan     2050620496  010:39 pts/0    00:00:00bash
alan     20520  1454  010:39?        00:00:00 nginx: master process nginx
alan     2052120520  010:39?        00:00:00 nginx: worker process
alan     2052620506  010:39 pts/0    00:00:00manps
alan     2053620526  010:39 pts/0    00:00:00 pager
alan     2056420496  010:40 pts/1    00:00:00bash

您可以在上面 ps 命令的输出中看到 Nginx 进程。这个命令显示了将近 300 行,但是我在这个例子中缩短了它。可以想象,试图处理 300 行过程信息有点混乱。我们可以将这个输出输送到 grep,过滤一下仅显示 nginx。

alan@workstation:~$ ps-ef |grep nginx
alan     20520  1454  010:39?        00:00:00 nginx: master process nginx
alan     2052120520  010:39?        00:00:00 nginx: worker process

确实更好了。我们可以很快看到,Nginx 有 20520 和 20521 的 PID。

2、PGREP
pgrep 命令更加简化单独调用 grep 遇到的问题。

alan@workstation:~$ pgrep nginx
20520
20521

假设您在一个托管环境中,多个用户正在运行几个不同的 Nginx 实例。您可以使用 -u 选项将其他人排除在输出之外。

alan@workstation:~$ pgrep -u alan nginx
20520
20521

3、PIDOF

另一个好用的是 pidof。此命令将检查特定二进制文件的 PID,即使另一个同名进程正在运行。为了建立一个例子,我将我的 Nginx 复制到第二个目录,并以相应的路径前缀启动。在现实生活中,这个实例可能位于不同的位置,例如由不同用户拥有的目录。如果我运行两个 Nginx 实例,则pidof 输出显示它们的所有进程。

alan@workstation:~$ ps-ef |grep nginx
alan     20881  1454  011:18?        00:00:00 nginx: master process ./nginx -p /home/alan/web/prod/nginxsec
alan     2088220881  011:18?        00:00:00 nginx: worker process
alan     20895  1454  011:19?        00:00:00 nginx: master process nginx
alan     2089620895  011:19?        00:00:00 nginx: worker process

使用 grep 或 pgrep 将显示 PID 数字,但我们可能无法辨别哪个实例是哪个。

alan@workstation:~$ pgrep nginx
20881
20882
20895
20896

pidof 命令可用于确定每个特定 Nginx 实例的 PID。

alan@workstation:~$ pidof/home/alan/web/prod/nginxsec/sbin/nginx
2088220881
alan@workstation:~$ pidof/home/alan/web/prod/nginx/sbin/nginx
2089620895

4、TOP

top 命令已经有很久的历史了,对于查看运行进程的细节和快速识别内存消耗等问题是非常有用的。其默认视图如下所示。

top-11:56:28 up 1 day,13:37,  1 user,  load average:0.09,0.04,0.03
Tasks:292 total,   3 running,225 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0.1 us,  0.2 sy,  0.0 ni,99.7id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiBMem:16387132 total,10854648 free,  1859036 used,  3673448 buff/cache
KiBSwap:        0 total,        0 free,        0 used.14176540 avail Mem
  PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND
17270 alan      20   03930764247288  98992 R   0.7  1.5   5:58.22 gnome-shell
20496 alan      20   0  816144  45416  29844 S   0.5  0.3   0:22.16 gnome-terminal-
21110 alan      20   0   41940   3988   3188 R   0.1  0.0   0:00.17top
    1 root      20   0  225564   9416   6768 S   0.0  0.1   0:10.72systemd
    2 root      20   0       0      0      0 S   0.0  0.0   0:00.01 kthreadd
    4 root       0-20       0      0      0 I   0.0  0.0   0:00.00 kworker/0:0H
    6 root       0-20       0      0      0 I   0.0  0.0   0:00.00 mm_percpu_wq
    7 root      20   0       0      0      0 S   0.0  0.0   0:00.08 ksoftirqd/0

可以通过键入字母 s 和您喜欢的更新秒数来更改更新间隔。为了更容易监控我们的示例 Nginx 进程,我们可以使用 -p 选项并传递 PID 来调用 top。这个输出要干净得多。

alan@workstation:~$ top -p20881 -p20882 -p20895 -p20896
Tasks:   4 total,   0 running,   4 sleeping,   0 stopped,   0 zombie
%Cpu(s):  2.8 us,  1.3 sy,  0.0 ni,95.9id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiBMem:16387132 total,10856008 free,  1857648 used,  3673476 buff/cache
KiBSwap:        0 total,        0 free,        0 used.14177928 avail Mem
  PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND
20881 alan      20   0   12016    348      0 S   0.0  0.0   0:00.00 nginx
20882 alan      20   0   12460   1644    932 S   0.0  0.0   0:00.00 nginx
20895 alan      20   0   12016    352      0 S   0.0  0.0   0:00.00 nginx
20896 alan      20   0   12460   1628    912 S   0.0  0.0   0:00.00 nginx

在管理进程,特别是终止进程时,正确确定 PID 是非常重要。此外,如果以这种方式使用 top,每当这些进程中的一个停止或一个新进程开始时,top 都需要被告知有新的进程。

六、终止进程

1、KILL

有趣的是,没有 stop 命令。在 Linux 中,有 kill 命令。kill 用于向进程发送信号。最常用的信号是"终止"(SIGTERM)或"杀死"(SIGKILL)。然而,还有更多。下面是一些例子。完整的列表可以用 kill -L 显示。

 1) SIGHUP       2) SIGINT       3) SIGQUIT      4) SIGILL       5) SIGTRAP
 6) SIGABRT      7) SIGBUS       8) SIGFPE       9) SIGKILL     10) SIGUSR1
11) SIGSEGV     12) SIGUSR2     13) SIGPIPE     14) SIGALRM     15) SIGTERM

注意第 9 号信号是 SIGKILL,通常,我们会发出比如 kill -9 20896 这样的命令。默认信号是 15,这是 SIGTERM。请记住,许多应用程序都有自己的停止方法。Nginx 使用 -s 选项传递信号,如 stop 或 reload。通常,我更喜欢使用应用程序的特定方法来停止操作。然而,我将演示用 kill 命令来停止 Nginx 进程 20896,然后用 pgrep 确认它已经停止。PID 20896 就不再出现。

alan@workstation:~$ kill -9 20896

alan@workstation:~$ pgrep nginx
20881
20882
20895
22123

2、PKILL

命令 pkill 类似于 pgrep,因为它可以按名称搜索。这意味着在使用 pkill 时必须非常小心。在我的 Nginx 示例中,如果我只想杀死一个 Nginx 实例,我可能不会选择使用它。我可以将 Nginx 选项 -s stop 传递给特定的实例来消除它,或者我需要使用 grep 来过滤整个 ps 输出。

/home/alan/web/prod/nginx/sbin/nginx -s stop
/home/alan/web/prod/nginxsec/sbin/nginx -s stop

如果我想使用 pkill,我可以包括 -f 选项,让 pkill 过滤整个命令行参数。这当然也适用于 pgrep。所以,在执行 pkill -f 之前,首先我可以用 pgrep -a 确认一下。

alan@workstation:~$ pgrep -a nginx
20881 nginx: master process ./nginx -p /home/alan/web/prod/nginxsec
20882 nginx: worker process
20895 nginx: master process nginx
20896 nginx: worker process

我也可以用 pgrep -f 缩小我的结果。pkill 使用相同参数会停止该进程。

alan@workstation:~$ pgrep-f nginxsec
20881
                                           
alan@workstation:~$ pkill-f nginxsec

pgrep(尤其是 pkill)要记住的关键点是,您必须始终确保搜索结果准确性,这样您就不会无意中影响到错误的进程。

猜你喜欢

转载自blog.csdn.net/m0_37886429/article/details/82965585