我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

前言

进程管理的作用:

  • 判断服务器健康状态:通过分析进程的状态(内存、CPU占有率等)判断服务器的负载和安全状态
  • 查看系统中的所有进程
  • 杀死进程

本文将给大家详细介绍关于linux管理进程命令的相关内容,通过这些关键的命令来全程管理你的应用。

一般来说,应用程序进程的生命周期有三种主要状态:启动、运行和停止。如果我们想成为称职的管理员,每个状态都可以而且应该得到认真的管理。这八个命令可用于管理进程的整个生命周期。

启动进程

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


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

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

PGREP

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


alan@workstation:~$ pgrep nginx
20520
20521

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


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

PIDOF

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


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 ngipbGxBBkYGnx: 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

可以通过键入字母 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.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

有趣的是,没有 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 2pbGxBBkYG0896 这样的命令。默认信号是 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

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 )要记住的关键点是,您必须始终确保搜索结果准确性,这样您就不会无意中影响到错误的进程。

大多数这些命令都有许多命令行选项,所以我总是建议阅读每一个命令的 man 手册页 。虽然大多数这些命令都存在于 Linux、Solaris 和 BSD 等平台上,但也有一些不同之处。在命令行工作或编写脚本时,始终测试并随时准备根据需要进行更正。

via: https://opensource.com/article/18/9/linux-commands-process-management

作者: Alan Formy-Duval 选题: lujun9972 译者: heguangzhi 校对: wxy

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

前言 进程管理的作用:判断服务器健康状态:通过分析进程的状态(内存、CPU占有率等)判断服务器的负载和安全状态查看系统中的所有进程杀死进程本文将给大家详细介绍关于linux管理进程命令的相关内容,通过这些关键的命令来全程管理你的应用。 一般
2022-06-04

Linux有效管理进程的命令

本篇内容主要讲解“Linux有效管理进程的命令”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux有效管理进程的命令”吧!一般来说,应用程序进程的生命周期有三种主要状态:启动、运行和停止。如
2023-06-16

Linux进程管理的命令有哪些

这篇文章主要介绍“Linux进程管理的命令有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Linux进程管理的命令有哪些”文章能帮助大家解决问题。1.ps‘ps’是Lin
2023-06-28

Linux进程管理命令有哪些

这篇“Linux进程管理命令有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Linux进程管理命令有哪些”文章吧。执行中
2023-06-27

12个linux进程管理命令介绍

执行中的程序在称作进程。当程序以可执行文件存放在存储中,并且运行的时候,每个进程会被动态得分配系统资源、内存、安全属性和与之相关的状态。可以有多个进程关联到同一个程序,并同时执行不会互相干扰。操作系统会有效地管理和追踪所有运行着的进程。为了
2022-06-03

Linux中常用的进程管理命令有哪些

本篇内容主要讲解“Linux中常用的进程管理命令有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux中常用的进程管理命令有哪些”吧!1.ps‘ps’是Linux
2023-06-27

Linux之进程的虚拟地址空间,逻辑地址和物理地址,进程管理命令

目录进程的虚拟地址空间1.内核空间(1G)2 栈(stack)3 内存映射段(mmap)4 堆(heap)5 .BSS段6 数据段(.Data)7 代码段(text)8 保留区逻辑地址进程管理命令进程恢复总结进程的虚拟地址空间 进程有自己的
2023-03-23

Linux后台进程管理的常用命令

这篇文章主要介绍“Linux后台进程管理的常用命令”,在日常操作中,相信很多人在Linux后台进程管理的常用命令问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Linux后台进程管理的常用命令”的疑惑有所帮助!
2023-06-13

Linux系统中有哪些内核管理的命令

本篇内容主要讲解“Linux系统中有哪些内核管理的命令”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux系统中有哪些内核管理的命令”吧!1、lsmod 列加以挂载的内核模块;lsmod 是
2023-06-12

Linux系统管理中有哪些常用的shell命令

本篇内容主要讲解“Linux系统管理中有哪些常用的shell命令”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux系统管理中有哪些常用的shell命令”吧!1.显示消耗内存/CPU最多的1
2023-06-09

LINUX中如何利用远程管理命令进行关机和重启

这篇文章给大家分享的是有关LINUX中如何利用远程管理命令进行关机和重启的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。方法如下1、打开LINUX,这里用UBUNTU操作系统,打开左边的终端窗口。2、直接输入shu
2023-06-13

Linux中Kill命令的进程调度该如何理解

这篇文章主要为大家分析了Linux中Kill命令的进程调度该如何理解的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“Linux中Kill命令的进程调度该如何理
2023-06-28

Linux系统中有哪些常用的系统管理命令

Linux系统中有哪些常用的系统管理命令?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。df1.作用df命令用来检查文件系统的磁盘空间占用情况,使用权限是所有用户。2.格式d
2023-06-10

收集的55个Linux系统管理中常用的一些shell命令

1.显示消耗内存/CPU最多的10个进程ps aux | sort -nk +4 | tailps aux | sort -nk +3 | tail2.查看进程 按内存从大到小排列ps -e -o "%C : %p : %z : %a"
2022-06-04

怎么在Linux中查找一个命令或进程的执行时间

这篇文章主要讲解了“怎么在Linux中查找一个命令或进程的执行时间”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么在Linux中查找一个命令或进程的执行时间”吧!在 Linux 中查找一个
2023-06-15

如何在 Linux 中查找一个命令或进程的执行时间

在类 Unix 系统中,你可能知道一个命令或进程开始执行的时间,以及一个进程运行了多久。 但是,你如何知道这个命令或进程何时结束或者它完成运行所花费的总时长呢? 在类 Unix 系统中,这是非常容易的! 有一个专门为此设计的程序名叫 GNU
2022-06-04

Linux 进程管理中的CFS负载均衡有什么用

本篇内容介绍了“Linux 进程管理中的CFS负载均衡有什么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 什么是负载均衡?前面的调度学习
2023-06-15

【Linux】Linux环境变量的理解 --- 命令行参数、shell子进程、环境变量、本地变量…

加油布鲁斯,你能行的! 文章目录 一、环境变量PATH中的系统默认搜索路径1.将程序安装到/usr/bin目录(不带./运行自己写的程序)2.将程序路径添加到PATH环境变量里面(不带./运行自己写的程序) 二、环境变量的深度
2023-08-25

编程热搜

目录