文章目录
- 零、学习目标
- 一、导入新课
- 二、新课讲解
- (一)进程概述
- 1、基本概念
- 2、三维度看待进程
- 3、引入多道编程模型
- (1)CPU利用率与进程数关系
- (2)从三个视角看多进程
- 4、进程的产生和消亡
- (1)进程的产生
- (2)进程的消亡
- 5、进程三种状态
- 6、进程ID(PID)
- 7、终端设备类类型
- (1)TTY(TeleTYpewriter)
- (2)PTY(Pseudo-TTY)
- (二)查看进程
- 1、进程查看命令 - ps
- (1)命令作用
- (2)参数说明
- (3)操作案例
- 2、Linux进程状态
- 3、观察进程变化命令 - top
- (1)参数选项
- (2)操作案例演示
- 4、查看进程树命令 - pstree
- (1)命令概述
- (2)安装pstree
- (3)参数说明
- (4)操作案例演示
- (三)杀死进程 - kill命令
- 1、命令作用
- 2、参数说明
- 3、操作案例演示
- (四)系统资源监控
- 1、free命令
- 2、uname命令
- 3、uptime命令
- 4、netstat命令
- 5、vmstat命令
- (五)任务管理
- 1、前台进程
- 2、后台进程
- 3、操作案例演示
- 三、归纳总结
- 四、上机操作
零、学习目标
- 查看进程与杀死进程
- 系统资源监控
- 任务管理
一、导入新课
- 在Linux系统中,进程是执行中的程序实例。我们需要学会如何查看和管理这些进程,以便更好地了解系统的运行状态,并进行必要的调整和优化。此外,我们还需要学会如何监控系统的资源使用情况,以便及时发现并解决可能出现的问题。通过学习本节的内容,我们将能够熟练地使用各种命令行工具来查看和管理进程、监控系统资源以及进行任务管理,从而提高我们的工作效率和系统的稳定性。
二、新课讲解
- 在Linux系统中,进程管理是一项非常重要的任务。通过掌握进程管理的相关知识和技能,我们可以更好地监控系统的运行状态,及时发现并解决问题,从而提高工作效率和系统的稳定性。
- 本节我们将学习如何查看和管理进程、如何进行系统资源监控以及如何进行任务管理。首先,我们将介绍进程的基本概念和模型,包括进程的产生和消亡、三状态以及进程ID等。接下来,我们将学习如何使用各种命令行工具来查看进程、杀死进程以及监控系统资源。最后,我们将学习如何管理和控制前台和后台进程,并通过一些操作案例来加深理解和应用。
- 总之,通过学习本节的内容,我们将能够更好地理解和掌握Linux系统中的进程管理,从而更加熟练地使用这些基本的命令行工具来完成各种常见的文件和目录操作任务。
(一)进程概述
- 在计算机系统中,进程是操作系统进行资源分配和调度的基本单位。本节我们将从基本概念、三维度看待进程模型、进程的产生和消亡以及进程的三种状态等方面对进程进行概述。
1、基本概念
- 进程 = 程序 + 执行。在计算机系统中,进程是指正在运行的程序实例。当一个程序被加载到内存中并开始执行时,就会创建一个新的进程。每个进程都有自己的地址空间,并且可以独立地进行计算和处理任务。
- 简单来说,进程就是程序与CPU运算的结合体。当我们把一个程序从磁盘中加载到内存中后,CPU就开始对这个程序进行运算和处理。此时,我们可以说这个程序变成了一个进程。进程是操作系统进行资源分配和调度的基本单位,它能够独立地进行计算和处理任务,从而实现多道编程,提高CPU的利用率。
2、三维度看待进程
(1)内存维度:每个进程都独占一块地址空间,CPU处理进程实际上就是处理这个进程内存中的数据信息。这意味着,当一个进程正在执行时,它所占用的内存是不能被其他进程访问的。
(2)执行的逻辑维度:每一个进程都可以被CPU所处理和计算,此外,每一个进程也可以挂起,让其他进程得以处理。在同一个时刻,只能有一个进程被cpu所处理。这意味着,虽然操作系统可以同时运行多个进程,但是在微观上,这些进程是按照顺序依次被执行的。因此,在单核架构下,进程模型实际上是“串行”处理的。然而,在多核架构下,进程模型可以在宏观和微观上都是并行处理的。
(3)时间维度:每个进程执行一段时间之后,肯定都完成了一定的工作量。即进程是随时间向前推进的。这意味着,进程是在不断变化和发展中的,而不是静态不变的。
- 进程让每个用户感觉自己独占CPU:在计算机系统中,进程是指正在运行的程序实例。当一个程序被加载到内存中并开始执行时,就会创建一个新的进程。每个进程都有自己的地址空间,并且可以独立地进行计算和处理任务。由于每个进程都独占一块地址空间,因此CPU在处理进程时实际上是处理这个进程内存中的数据信息。这意味着,即使多个用户同时使用同一台计算机,他们各自的进程也可以各自独立地进行计算和处理任务,从而让用户感觉像是自己独占了CPU一样。此外,在多道编程模型下,操作系统会将多个进程分配到不同的处理器核心上,并且在宏观上是并行处理的。因此,即使在同一时刻有多个进程在运行,用户仍然可以感觉到自己的进程得到了及时的响应和处理,就像是自己独占了CPU一样。
3、引入多道编程模型
(1)CPU利用率与进程数关系
- CPU利用率与进程数关系图
- 在计算机系统中,进程是指正在运行的程序实例。操作系统可以同时处理多个进程,这就是多道编程模型。而在最开始的操作系统中,采用的是单道编程模型,即一个程序处理完,再处理下一个程序。
- 单道编程模型的缺点是响应时间慢和CPU利用率非常低。例如,假设一个进程中有20%需要做CPU运算,80%在做IO(发送IO事件时,CPU时闲置的),那么CPU利用率就是20%。而采用单道编程模型,CPU利用率只能达到1-0.8=20%。
- 为了提高CPU的利用率,引入了多道编程模型。多道编程模型可以让操作系统同时处理多个进程,从而提高了CPU的利用率。例如,同时执行两个进程,CPU利用率可以达到1-0.8×0.8=36%;同时执行三个进程,CPU利用率可以达到1-0.8×0.8×0.8=48.8%。
- 因此,引入进程模型的目的就是为了满足多道编程,而多道编程的目的就是为了提高CPU的利用率。随着进程数量的增加,CPU的利用率也会逐步提高。
(2)从三个视角看多进程
- 物理视角、逻辑视角和时序视角
- 物理视角:从物理资源分配的角度看多进程。每个进程都有自己的独立内存空间,包括代码段、数据段和堆栈段等。操作系统为每个进程分配相应的物理资源,并通过虚拟内存管理技术实现进程之间的隔离。这样,即使多个进程同时运行,它们也不会相互干扰。
- 逻辑视角:从逻辑执行顺序的角度看多进程。在多进程系统中,多个进程可以并发地执行,即在同一时间内有多个进程处于运行状态。然而,由于单个处理器只能执行一个指令流,所以实际上这些进程是交替执行的。操作系统通过调度算法决定哪个进程应该获得CPU并进行计算,从而实现了并发执行的效果。
- 时序视角:从时间轴上看多进程。在一个时间段内,多个进程按照一定的顺序执行。这种顺序可能受到许多因素的影响,如优先级、等待I/O操作的时间、系统的负载情况等。操作系统会根据这些因素调整进程的执行顺序,以达到最优的性能和响应速度。
- 总结来说,物理视角关注的是资源分配,逻辑视角关注的是执行顺序,而时序视角关注的是时间轴上的进程行为。理解这三个视角有助于我们更好地理解和控制多进程系统的行为。
4、进程的产生和消亡
(1)进程的产生
- 操作系统产生服务进程:操作系统在启动时会创建一些必要的服务进程,如网络服务、文件系统服务等。
- 父进程创建子进程:一个已经存在的进程可以创建一个新的进程,这个新进程被称为子进程。父进程和子进程共享相同的代码和数据空间,但拥有不同的堆栈和寄存器状态。
- 用户请求创建一个进程:用户可以通过执行程序或命令来创建一个新的进程。例如,在Linux系统中,用户可以通过输入
./program_name
来运行一个程序,并创建一个新的进程。
(2)进程的消亡
- 进程的所有运算都处理完之后,自行退出:当一个进程完成所有运算并返回结果后,它将自动退出。这是正常情况下进程结束的方式。
- 进程在运行过程中产生错误或异常而强行退出:如果一个进程在运行过程中发生了错误或异常,操作系统可能会终止该进程。这通常会导致进程的资源被释放,以便其他进程使用。
- 一个进程被其他进程所杀死而退出:在一个多任务系统中,一个进程可以被另一个进程杀死。这种情况下,被杀死的进程将立即停止执行,并释放其占用的资源。
5、进程三种状态
- 进程有三种状态:
执行态(Running)
、就绪态(Ready)
和阻塞态(Blocking)
。在执行态,一个进程正在被CPU运行;在就绪态,一个进程已经准备好被执行,但还没有被分配到CPU上;在阻塞态,一个进程由于某些原因无法继续执行,需要等待某种条件满足才能恢复执行。 - 对于挂起态,它可能是由于发生了某些阻塞操作,比如I/O事件。例如,当一个进程需要从磁盘读取数据时,它会进入阻塞态,直到数据被读取完毕。此外,一个进程也可能会主动挂起自己,以便让其他进程得以处理。例如,一个长时间运行的进程可能会主动挂起自己,以避免占用过多的CPU资源。最后,用户也可以主动将进程挂起,比如使用sleep操作来暂停进程的执行。
- 需要注意的是,对于第一类和第三类挂起的进程,即使把CPU让给这个进程,CPU也无法处理它,因此我们将这样的进程称为阻塞态进程。而第二类进程,我们称之为就绪态进程,因为它们已经准备好被执行,只需要被分配到CPU上就可以开始执行。
- 进程三状态转换图
- 创建态 → 就绪态:当一个进程被创建时,它会进入创建态,然后经过初始化后,如果所有必要的资源都可用,则变为就绪态。
- 就绪态 → 运行态:当CPU从系统中的就绪队列选择一个进程进行执行时,该进程的状态将从就绪态变为运行态。
- 运行态 → 就绪态:当一个正在运行的进程的时间片用完或者被高优先级的进程抢占时,它的状态将从运行态变为就绪态。
- 运行态 → 阻塞态:当一个运行中的进程请求某种I/O操作或其他资源而不能立即得到满足时,它的状态将从运行态变为阻塞态。
- 阻塞态 → 就绪态:当导致进程阻塞的事件发生并且相关资源变得可用时,进程的状态将从阻塞态变为就绪态。
- 任何状态 → 终止态:当一个进程完成其工作或者遇到错误需要退出时,它可以从任何状态直接进入终止态。
6、进程ID(PID)
- 在Linux中,进程启动时,操作系统会为其分配一个唯一的进程ID(PID)。这个PID用于标识系统中的每一个进程。通过执行命令ps -aux,可以查看系统中所有正在运行的进程及其详细信息。
- 执行命令:
ps -aux
,查看进程详情
7、终端设备类类型
- TTY和PTY是计算机术语,用于描述终端设备的类型。
(1)TTY(TeleTYpewriter)
- TTY最初是指一种电传打字机设备,它通过串行线路发送和接收数据。在现代计算机系统中,TTY通常用来指代任何类型的字符设备,如控制台、伪终端等。TTY设备可以直接与操作系统进行交互,通常用于登录、命令行界面和其他文本输入输出操作。
(2)PTY(Pseudo-TTY)
-
PTY也称为虚拟终端或伪终端,是一种软件模拟的TTY设备。PTY允许在一个进程之间创建一个“哑”终端,使得该进程可以像真正的TTY设备一样工作。这使得一个程序可以在没有实际物理TTY设备的情况下与另一个程序进行交互,例如远程登录到另一台机器上时使用的SSH协议就是一个例子。
-
简单来说,TTY是硬件上的字符设备接口,而PTY是软件模拟的TTY设备。
(二)查看进程
1、进程查看命令 - ps
- ps: process status
(1)命令作用
- 将某个时间点的程序运作情况截取下来。
(2)参数说明
参数 | 作用 |
---|---|
a | 和输入终端关联的所有进程,通常与x一起使用,列出完整信息。 |
x | 后台进程,通常与a 这个参数一起使用,可列出较完整信息 |
u | 有效使用者相关的进程 |
(3)操作案例
- 执行命令:
ps la | head -5
,能够观察所有系统的数据
- 执行命令:
ps axjf | head -20
,连同部分程序树状态
- 执行命令:
ps l
仅查看自己的bash相关的进程
- 执行命令:
ps aux
观察系统所有进程
属性 | 含义 |
---|---|
USER | 进程使用者 |
PID | 进程标识符 |
%CPU | 进程使用掉的CPU 资源百分比 |
%MEM | 进程所占用的物理内存百分比 |
VSZ | 进程使用掉的虚拟内存量(KBytes) |
RSS | 进程占用的物理的内存量(KBytes) |
TTY | 进程在哪个终端机上面运作,若与终端机无关则显示?, 另外, tty1-tty6 是本机上面的登入者程序,若为pts/0 等等的,则表示为由网络连接进主机的程序 |
STAT | 进程目前的状态,状态显示与ps -l 的S旗标相同(R/S/D/T/Z) |
START | 进程被触发启动的时间 |
TIME | 进程实际使用CPU运作的时间 |
COMMAND | 进程的实际命令 |
2、Linux进程状态
状态值 | 含义 |
---|---|
R (TASK_RUNNING ) | 指正在被CPU运行或者就绪的状态(在run_queue队列里的状态) |
S (TASK_INTERRUPTIBLE ) | 可中断的睡眠状态,处于等待状态中的进程,一旦被该进程等待的资源被释放,那么该进程就会进入运行状态 |
D (TASK_UNINTERRUPTIBLE ) | 不可中断的睡眠状态,该状态的进程只能用wake_up()函数唤醒。 |
T (TASK_STOPPED / TASK_TRACED ) | 当进程收到信号SIGSTOP、SIGTSTP、SIGTTIN或SIGTTOU时就会进入暂停状态。可向其发送SIGCONT信号让进程转换到可运行状态。 |
Z (TASK_DEAD -EXIT_ZOMBIE ) | 僵尸进程:当进程已经终止运行,但是父进程还没有询问其状态的情况。不可被kill,即不响应任务信号,无法用SIGKILL杀死。 |
3、观察进程变化命令 - top
(1)参数选项
选项 | 含义 |
---|---|
-d | 后面可以接秒数,就是整个程序画面更新的秒数;默认5秒。 |
-b | 以批次方式执行top,还有更多参数可以使用,通常会搭配数据流重导向来将批次的结果输出成为档案。 |
-n | 与-b 搭配,作用是需要进行几次top的输出结果。 |
-p | 指定某些个PID 来进行观察监测。 |
(2)操作案例演示
- 执行命令:
top -d 3
,每隔三秒更新一次数据
- 执行命令:
top -b -n 2
,进行两次top的输出结果
4、查看进程树命令 - pstree
(1)命令概述
- pstree命令用于查看进程树之间的关系,即哪个进程是父进程,哪个是子进程,可以直观地看出是谁创建了谁。Linux 系统中进程之间的关系就是一棵树,树的根就是进程 PID 为 1 的 init 进程。
(2)安装pstree
- 执行命令:
pstree
,报错找不到命令,说明CentOS7默认没有安装pstree
- 执行命令:
yum -y install psmisc
(3)参数说明
参数 | 含义 |
---|---|
-A | 各进程树之间的连接以 ASCII 码字符来连接 |
-U | 各进程树之间的连接以 utf8 字符来连接,某些终端可能会有错误 |
-p | 同时列出每个进程的 PID |
-u | 同时列出每个进程的所属账号名称 |
(4)操作案例演示
- 执行命令:
pstree
- 执行命令:
pstree -Aup
(三)杀死进程 - kill命令
1、命令作用
- kill发送信号,并不只是杀进程。
2、参数说明
参数 | 函数 |
---|---|
-l | 这个是L的小写,列出目前kill 能够使用的信号(signal)有哪些? signal 向进程发送的信号,指示其进行不同操作。用man 7 signal 可知。 |
-15 | 以正常的程序方式终止一个进程!!! |
-9 | 立刻强制终止一个进程!!! |
-2 | 代表由键盘输入[Ctrl + C] 同样的动作 |
-1 | 对于sshd这样的守护进程,重新读取一次参数的配置文件(类似reload),如果进程为非守护进程,默认为终止进程 |
3、操作案例演示
-
执行命令:
pstree -aup | grep sshd
-
用参数
-1
来杀910进程,执行命令:kill -1 910
-
说明没有杀死sshd进程,又重新加载了
-
用参数
-9
来杀死这个守护进程sshd,执行命令:kill -9 910
-
启动firewalld进程并查看其进程树
-
问题:父进程被kill掉,它的子进程是否就一起被kill掉?
-
结论:父进程被kill掉了,但是其子进程还依然存在。
-
如果任务是杀死所有用户的firewalld进程,那么就需要多次发布kill命令,很烦的,怎么办呢?Linux提供了一个很好的命令:killall。
-
利用killall命令杀死所有用户的firwalld进程
(四)系统资源监控
1、free命令
- 观察内存(memory)使用情况
2、uname命令
- 查阅系统与核心相关信息
3、uptime命令
- 观察系统启动时间与工作负载
4、netstat命令
- 网络状态监控,CentOS7默认没有安装netstat,需要自行安装
- 执行命令:
yum -y install net-tools
- 执行命令:
netstat -atp
- 执行命令:
netstat -antp
- 执行命令:
netstat -lntp
5、vmstat命令
- 侦测系统资源变化,CPU/内存/磁盘输入输出状态
- 执行命令:
vmstat 1 4
,统计目前主机CPU状态,每秒一次,共计四次
(五)任务管理
1、前台进程
- 可以控制与执行命令的bash环境称为前台进程。
2、后台进程
- 在操作系统中自行运行,你无法使用[Ctrl + C]终止,可使用bg/fg命令操作的任务。
- 后台执行的任务不能接收终端(terminal/shell)的输入。
3、操作案例演示
-
Ctrl+Z切换到后台,或者执行命令:
tail -F anaconda-ks.cfg &
-
在当前bash执行多个任务
-
观察后台任务,用jobs命令(后台任务是一个任务栈,
+
表明该任务处于栈顶,发布fg
命令,只有处于栈顶的后台任务才能切换成前台任务)
-
执行命令:
jobs -r
# r: Running
-
执行命令:
jobs -s
# s: Stopped
-
执行命令:
jobs -l
,可以显示后台任务进程号
-
三种任务状态:Running, Stopped, Killed
-
执行命令:
pstree -aup
,查看进程树的sshd部分
-
利用
fg
命令可以将后台任务切换到前台,注意每次发布fg
命令,只能将处于任务栈顶的后台任务(编号后是“+
”的后台任务)切换到前台进行处理,然后栈顶的下一个任务就成为新的栈顶任务,其编号后的“-
”就会变成“+
”。 -
发布一次fg命令
-
进入末行模式,输入q,不存盘退出。
-
执行命令:
jobs -l
-
现在,执行
fg
命令之后,2768
这个处于栈顶的后台任务会变成前台任务来处理,但是我们暂时不把该任务切换到前台。我们试着杀死该后台任务。 -
停止作业:
kill -15 2768
-
事实表明,删不掉vim作业,应该使用参数-9
-
再次执行命令:
fg
-
小结:通过
fg
命令,可以不断把栈顶的作业从后台变成前台作业来处理。
三、归纳总结
- 回顾本节课所讲的内容,并通过提问的方式引导学生解答问题并给予指导。
四、上机操作
- 形式:单独完成
- 题目:完成进程管理
- 要求:按照讲课笔记完成显示进程、杀死进程与作业前后台切换任务