8个有效的Linux进程管理命令

图片涟源:opensource.com
一般来说,应用程序的生命周期有三个主要的状态:开始、运行和停止。如果我们想成为称职的进程管理者,每个状态都可以而且应该认真地管理。这八个命令可以用于在整个生命周期中管理进程。

启动过程

启动进程最简单的方法是在命令行中输入其名称并按下回车键(Enter)。如果您想启动Nginx Web服务器,请输入“nginx”。如果你只是想检查一下版本,输入“nginx -v”。

alan@workstation:~$ 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

我将使用流行的Web服务器软件nginx作为示例。假设已经安装了nginx,如果which nginx命令不返回任何内容,则没有找到nginx,因为它只搜索你定义的可执行路径。有三种方法来弥补一个进程(或应用程序)不能简单地按名称启动的情况。第一种方法是输入完整路径。不过,我宁愿不把所有的都打出来,你呢?

alan@workstation:~$ /home/alan/web/prod/nginx/sbin/nginx -v
nginx version: nginx/1.14.0

第二种解决方案是将应用程序安装到可执行文件路径中的目录中。但是,这有可能是不行的,特别是在你没有root权限的时候。
第三种解决方案是更新可执行路径环境变量,以包括安装要使用的特定应用程序的目录。这个解决方案是依赖于shell的。例如,bash用户需要在.bashrc文件中编辑“PATH=”这一行。

PATH="$HOME/web/prod/nginx/sbin:$PATH"

现在,重新使用“echo”和“which”命令,或者尝试查看版本。这就容易多了!

alan@workstation:~$ echo $PATH
/home/alan/web/prod/nginx/sbin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin

alan@workstation:~$ which nginx
/home/alan/web/prod/nginx/sbin/nginx

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

保持进程运行

NOHUP

当注销或关闭终端时,进程可能无法继续运行。通过使用nohup命令运行,可以避免这种特殊情况。此外,附加一个“&”符号将把进程发后台运行,并允许用户继续使用该终端。例如,假设您想运行myprogram.sh。

nohup myprogram.sh &

nohup做的一件事就是返回运行过程的PID。接下来我将进一步讨论PID。

管理运行中的进程

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

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  0 Aug18 ?        00:00:10 /sbin/init splash
root         2     0  0 Aug18 ?        00:00:00 [kthreadd]
root         4     2  0 Aug18 ?        00:00:00 [kworker/0:0H]
root         6     2  0 Aug18 ?        00:00:00 [mm_percpu_wq]
root         7     2  0 Aug18 ?        00:00:00 [ksoftirqd/0]
root         8     2  0 Aug18 ?        00:00:20 [rcu_sched]
root         9     2  0 Aug18 ?        00:00:00 [rcu_bh]
root        10     2  0 Aug18 ?        00:00:00 [migration/0]
root        11     2  0 Aug18 ?        00:00:00 [watchdog/0]
root        12     2  0 Aug18 ?        00:00:00 [cpuhp/0]
root        13     2  0 Aug18 ?        00:00:00 [cpuhp/1]
root        14     2  0 Aug18 ?        00:00:00 [watchdog/1]
root        15     2  0 Aug18 ?        00:00:00 [migration/1]
root        16     2  0 Aug18 ?        00:00:00 [ksoftirqd/1]
alan     20506 20496  0 10:39 pts/0    00:00:00 bash
alan     20520  1454  0 10:39 ?        00:00:00 nginx: master process nginx
alan     20521 20520  0 10:39 ?        00:00:00 nginx: worker process
alan     20526 20506  0 10:39 pts/0    00:00:00 man ps
alan     20536 20526  0 10:39 pts/0    00:00:00 pager
alan     20564 20496  0 10:40 pts/1    00:00:00 bash

您可以在上面的ps命令的输出中看到nginx进程。命令显示了近300行,这里只显示了一部分。你可以想象,试图处理300行进程信息有点麻烦的。我们可以把这个输出通过使用grep来过滤nginx。

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

那样会更好。我们很快可以看到PID分别为为20520和20521的nginx进程。

PGREP

为了进一步简化操作,不用分别调用grep命令,从而创建了pgrep命令。

alan@workstation:~$ pgrep nginx
20520
20521

假设你位于一个同一时间多个用户运行了多个nginx的宿主环境中。你可以使用-u选项制定输出某个用户的nginx。

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

PIDOF

另一个漂亮的指令是pidof。即使正在运行另一个具有相同名称的进程,pidof命令也可以检查特定进程(二进制文件)的pid。为了举例说明,我将我的nginx复制到第二个目录,然后使用相应的前缀设置启动它。在实际应用中,程序可以在不同的路径下,例如不同的用户拥有相同的目录。如果我运行了两个nginx进程,则ps -ef会显示所有的进程。

alan@workstation:~$ ps -ef |grep nginx
alan     20881  1454  0 11:18 ?        00:00:00 nginx: master process ./nginx -p /home/alan/web/prod/nginxsec
alan     20882 20881  0 11:18 ?        00:00:00 nginx: worker process
alan     20895  1454  0 11:19 ?        00:00:00 nginx: master process nginx
alan     20896 20895  0 11: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
20882 20881

alan@workstation:~$ pidof /home/alan/web/prod/nginx/sbin/nginx
20896 20895

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.7 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem : 16387132 total, 10854648 free,  1859036 used,  3673448 buff/cache
KiB Swap:        0 total,        0 free,        0 used. 14176540 avail Mem

  PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND
17270 alan      20   0 3930764 247288  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.17 top
    1 root      20   0  225564   9416   6768 S   0.0  0.1   0:10.72 systemd
    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

top可以通过输入字母s后跟你希望更新的秒数来更改更新间隔。为了更容易监视我们的示例nginx进程,我们可以调用top并使用-p选项传递PID。 这个输出信息就更简洁。

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.9 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem : 16387132 total, 10856008 free,  1857648 used,  3673476 buff/cache
KiB Swap:        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指令这些新进程。

停止一个进程

KILL

有趣的是,没有停止命令。 在Linux中,有kill命令。 Kill用于向进程发送信号。 最常用的信号是“结束(terminate)”(SIGTERM)或“杀死(kill)”(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选项传递诸如“停止”或“重新加载”之类的信号。 通常,我更喜欢使用应用程序的特定方法来停止进程的运行。 但是,我将演示kill命令来停止nginx进程20896,然后使用pgrep命令确认它已经停止运行。 PID 20896不再出现。

alan@workstation:~$ kill -9 20896

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

PKILL

命令pkill和pgrep类似,pkill也可以按名称搜索。 这意味着你在使用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)要记住关键是你必须始终确保搜索结果是准确的,这样你才不会无意中影响其它的进程。

这些命令中的大多数都有许多命令行选项,因此我总是建议阅读每个命令的手册(man page)。 虽然大多数命令在Linux,Solaris和BSD等平台上通用,但存在一些差异。 在命令行工作或编写脚本时,始终做好验证,并在需要时随时准备好修正。
原文:8 Linux commands for effective process management

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值