大数据讲课笔记1.4 进程管理

news2024/11/18 0:00:32

文章目录

  • 零、学习目标
  • 一、导入新课
  • 二、新课讲解
    • (一)进程概述
      • 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)参数选项
        • (3)操作案例演示
      • 4、查看进程树命令 - pstree
        • (1)命令概述
        • (2)安装pstree
        • (3)参数说明
        • (4)操作案例演示
    • (三)杀死进程 - kill命令
      • 1、命令作用
      • 2、参数说明
      • 3、操作案例演示
    • (四)系统资源监控
      • 1、free命令
      • 2、uname命令
      • 3、uptime命令
      • 4、netstat命令
      • 5、vmstat命令
    • (五)任务管理
      • 1、前台进程
      • 2、后台进程
      • 3、前后台切换
      • 4、操作案例演示
  • 三、归纳总结
  • 四、上机操作

零、学习目标

  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设备。

(二)查看进程

  • 在Linux操作系统中,进程管理是系统管理员和开发者必须掌握的重要技能之一。通过有效的进程监控和管理,可以确保系统的稳定运行和资源的有效利用。本节将介绍一些常用的进程查看命令,包括pstoppstreeps命令用于查看某个时间点的程序运作情况,能够获取关于进程的详细信息,如PID、CPU使用率、内存使用量等。而top命令则可以实时地观察到进程的变化,显示了当前系统中各个进程的资源占用状况。此外,pstree命令则能以树状结构展示进程之间的关系,帮助我们更好地理解系统的运行状态。通过学习和掌握这些命令的使用,我们将能够更加有效地管理和优化我们的Linux系统。

1、进程查看命令 - ps

  • ps: process status
(1)命令作用
  • ps命令用于查看某个时间点的程序运作情况,能够获取关于进程的详细信息,如PID、CPU使用率、内存使用量等。
(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)命令作用
  • top命令则可以实时地观察到进程的变化,显示了当前系统中各个进程的资源占用状况。
(2)参数选项
选项含义
-d后面可以接秒数,就是整个程序画面更新的秒数;默认5秒。
-b以批次方式执行top,还有更多参数可以使用,通常会搭配数据流重导向来将批次的结果输出成为档案。
-n与-b 搭配,作用是需要进行几次top的输出结果。
-p指定某些个PID 来进行观察监测。
(3)操作案例演示
  • 执行命令:top -d 3,每隔三秒更新一次数据
    在这里插入图片描述
  • 执行命令:top -b -n 2,进行两次top的输出结果
    在这里插入图片描述
    在这里插入图片描述

4、查看进程树命令 - pstree

(1)命令概述
  • pstree命令是一个在Linux系统中用于查看进程树的实用工具。这个命令可以清晰地展示各个进程之间的关系,包括哪个进程是父进程,哪个是子进程。通过使用pstree命令,用户能够直观地了解到哪些进程是由哪些进程创建的。

  • 在Linux操作系统中,所有的进程构成了一棵进程树。这棵树的根就是PID(进程标识符)为1的init进程。每个进程都可以有多个子进程,而这些子进程又可以有自己的子进程,从而形成了一个树状结构。pstree命令就是用来显示这个进程树的。

  • 总的来说,pstree命令提供了一个简单且易于理解的方式来查看和理解Linux系统中的进程层次结构。

(2)安装pstree
  • 执行命令:pstree,报错找不到命令,说明CentOS7默认没有安装pstree
    在这里插入图片描述
  • 执行命令:yum -y install psmisc
    在这里插入图片描述
(3)参数说明
参数含义
-A各进程树之间的连接以 ASCII 码字符来连接
-U各进程树之间的连接以 utf8 字符来连接,某些终端可能会有错误
-p同时列出每个进程的 PID
-u同时列出每个进程的所属账号名称
(4)操作案例演示
  • 执行命令:pstree
    在这里插入图片描述
  • 执行命令:pstree -Aup
    在这里插入图片描述

(三)杀死进程 - kill命令

1、命令作用

  • kill命令在Linux和其他类Unix系统中用于发送一个信号给一个或多个进程。这个命令通常用来终止(杀死)一个运行中的程序,但也可以用来暂停、恢复或者更改进程的行为。

2、参数说明

  • kill命令可以接收一些选项,比如-s用于指定要发送的信号类型,-p用于列出指定进程的进程号,等等。如果不指定信号类型,默认会发送SIGTERM信号,这是请求进程优雅地关闭自己的一种方式。如果进程不响应,你可能需要发送更强制的信号,如SIGKILL(-9),这将立即结束进程,无法被忽略或捕获。
参数函数
-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进程
    在这里插入图片描述

(四)系统资源监控

  • 系统资源监控是计算机系统管理的重要组成部分。它可以帮助我们了解系统的运行状态,发现潜在的问题,并及时采取相应的措施进行优化和调整。本文将介绍几个常用的系统资源监控命令,包括观察内存使用情况的free命令,查阅系统与核心相关信息的uname命令,观察系统启动时间与工作负载的uptime命令,网络状态监控的netstat命令,以及侦测系统资源变化、CPU/内存/磁盘输入输出状态的vmstat命令。通过这些命令的使用,我们可以更好地掌握系统的运行状况,确保系统的稳定性和效率。对于运维人员来说,熟练掌握这些工具的使用方法是非常重要的。

1、free命令

  • free命令是Linux系统中的内存管理工具,用于显示系统的物理内存、交换空间和内核缓冲区的使用情况。通过指定选项,可以以字节、千字节、兆字节或吉字节为单位显示内存信息,并可以选择定时刷新输出结果。此外,free还可以提供总内存、已用内存、空闲内存、缓冲/缓存内存以及可用内存等详细信息,帮助用户了解系统内存使用状况。
选项说明
-b以字节为单位显示内存使用情况。
-k以千字节(KB)为单位显示内存使用情况。
-m以兆字节(MB)为单位显示内存使用情况。
-g以吉字节(GB)为单位显示内存使用情况。
-o不进行刷新操作。
-s delay每隔指定秒数刷新输出结果。
-t显示内存总和行。
-V显示版本信息。
  • 执行命令:free - mt,观察内存(memory)使用情况
    在这里插入图片描述
  • 总内存(total):系统的物理内存总量。
  • 已用内存(used):已被程序使用的物理内存。
  • 空闲内存(free):未被程序使用的物理内存。
  • 缓冲/缓存内存(buff/cache):系统用于缓冲和缓存数据的内存,这部分内存可以被其他程序快速复用。
  • 可用内存(available):可供当前运行的程序立即使用的内存总量,包括空闲内存和部分已用内存。

2、uname命令

  • uname命令是Linux系统中用于查看系统信息的实用工具,可以显示操作系统的名称、版本号、主机名、处理器架构等关键信息。通过使用不同的选项参数,用户可以获取到特定的系统属性,例如内核名称、操作系统发行版和机器类型等。uname命令对于系统管理员进行故障排查、软件安装或硬件兼容性检查等工作非常有用。
选项说明
-a 或 --all显示所有系统信息
-s 或 --kernel-name输出内核名称
-n 或 --nodename输出网络节点主机名
-r 或 --kernel-release输出内核发行版本号
-v 或 --kernel-version输出内核版本信息
-m 或 --machine输出机器类型(硬件平台)
-p 或 --processor输出处理器类型
-i 或 --hardware-platform输出硬件平台
-o 或 --operating-system输出操作系统名称
  • 执行命令:uname -a
    在这里插入图片描述
  • Linux:操作系统的名称
  • ied:主机名(网络节点名)
  • 3.10.0-1160.el7.x86_64:内核版本和发行版号。这个值包含了内核的主要版本号(3.10)、次要版本号(0)、补丁级别(1160)、发行版标识(el7)以及硬件架构(x86_64)。
  • #1 SMP Mon Oct 19 16:18:59 UTC 2020:编译内核时的时间戳、SMP(对称多处理)标志以及时区(UTC)。这个值表示了内核构建的具体日期和时间。
  • x86_64 x86_64 x86_64:机器类型和处理器架构。这里的三个x86_64分别代表系统类型、硬件平台和处理器类型。
  • 通过这些信息,用户可以了解系统的操作系统、内核版本、硬件平台等关键属性,这对于软件安装、硬件兼容性检查或故障排查等工作非常有用。

3、uptime命令

  • uptime命令是Linux系统中用于查看系统运行时间和负载信息的工具。它会显示当前时间、系统已经运行的时间、在线用户数量以及系统负载情况(过去1分钟、5分钟和15分钟内的平均负载)。通过使用uptime,用户可以了解系统的运行状况和性能表现,对于系统管理员进行监控和故障排查非常有用。
  • 执行命令:uptime
    在这里插入图片描述
  • 23:56:08:当前系统时间
  • up 16 min:系统已经运行了16分钟
  • 2 users:当前有2个用户在线
  • load average: 0.09, 0.16, 0.10:过去1分钟、5分钟和15分钟内的平均负载。这个值表示在特定时间内CPU正在处理的任务数(包括等待CPU时间的任务)。理想情况下,这些值应该接近或略低于系统中的处理器核心数量。
  • 通过这些信息,用户可以了解系统的运行时间和负载状况,有助于判断系统的性能表现和稳定性。

4、netstat命令

  • netstat命令是Linux系统中用于显示网络连接、路由表、接口统计等网络信息的工具。它可以帮助用户了解当前系统中的网络状态,包括活动的TCP和UDP连接、监听的端口以及网络接口的状态等。通过使用不同的选项参数,用户可以获取到特定的网络属性,例如查看所有活动连接(-a)、显示监听的TCP和UDP端口(-l)或查看路由表信息(-r)。netstat对于网络管理和故障排查非常有用。
  • CentOS7默认没有安装netstat,需要自行安装
  • 执行命令:yum -y install net-tools
    在这里插入图片描述
  • 执行命令:netstat -atp
    在这里插入图片描述
  • 执行命令:netstat -antp
    在这里插入图片描述
  • 执行命令:netstat -lntp
    在这里插入图片描述

5、vmstat命令

  • vmstat命令是Linux系统中用于显示虚拟内存统计信息的工具。它可以帮助用户了解系统的资源使用情况,包括CPU、内存、I/O和进程状态等。通过使用不同的选项参数,用户可以获取到特定的信息,例如查看每个核心的CPU使用率(-P ALL)、每两秒刷新输出结果(-S 2)或查看内存页面交换情况(-s)。vmstat对于系统管理和性能分析非常有用。
  • 执行命令:vmstat 1 4,统计目前主机CPU状态,每秒一次,共计四次
    在这里插入图片描述

(五)任务管理

  • 任务管理是操作系统中一项重要的功能,它涉及到对前台进程和后台进程的管理和控制。前台进程是指与用户直接交互的进程,它们在当前终端上运行,并且可以接收用户的输入;而后台进程是在后台运行的进程,不直接与用户交互,也不占用终端。通过学习如何操作前台和后台进程,我们可以更有效地利用系统资源,同时也能更好地进行多任务处理。本节将介绍如何切换前台和后台进程,查看后台任务,以及如何终止和恢复后台任务。这些知识对于Linux系统的使用者来说非常重要,尤其是那些需要在命令行环境中工作的开发者和技术人员。

1、前台进程

  • 前台进程是指与用户直接交互的进程,它在当前终端上运行,并且可以接收用户的输入。当一个前台进程正在运行时,该终端会被占用,不允许进行其他操作。例如,当你在一个终端窗口中打开文本编辑器或命令行程序时,它们就是前台进程。

2、后台进程

  • 后台进程是在后台运行的进程,不直接与用户交互,也不占用终端。这些进程可以在用户不再关注的情况下继续执行任务,同时用户可以在同一终端中启动新的进程或进行其他操作。通常情况下,后台进程不能接收来自终端的输入。例如,你可能在后台运行一个压缩文件的任务,而不需要实时监控它的进度。
  • 要将一个进程置于后台运行,通常需要在其后面加上"&"符号。例如,在Linux中,你可以使用command &来将命令command放在后台执行。

3、前后台切换

  • 切换前台和后台进程的方式取决于所使用的操作系统。在Unix-like系统中,可以通过按Ctrl+Z暂停前台进程,然后使用bg或fg命令将其发送到后台或恢复到前台。在某些系统中,也可以通过jobs命令查看当前会话中的所有后台作业。

4、操作案例演示

  • 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命令功能的简要总结。fg命令是Linux和Unix系统中的一个常用命令,用于将后台运行的任务切换到前台继续执行。在使用fg命令时,如果没有指定作业编号,默认会将当前栈顶的作业(即最后一个被放入后台的任务)调至前台。通过反复使用fg命令,用户可以按照自己的需要灵活地管理多个后台任务,方便地进行多任务处理。此外,结合其他相关的命令如bg(将作业放到后台运行)和jobs(查看后台作业列表),用户可以更好地控制和调度进程,提高工作效率。

三、归纳总结

  • 回顾本节课所讲的内容,并通过提问的方式引导学生解答问题并给予指导。
  • 本节主要介绍了Linux系统中的进程管理,包括进程的基本概念、多道编程模型、进程的产生和消亡、进程状态、进程ID以及终端设备类型。同时,还介绍了如何使用ps、top和pstree命令查看系统中的进程信息,如何使用kill命令结束一个或多个进程,以及如何使用free、uname、uptime、netstat和vmstat命令监控系统的内存使用、网络连接、CPU负载和磁盘I/O等情况。此外,还介绍了前台进程和后台进程的概念,以及如何在前后台之间切换,如何在bash中执行多个任务。

四、上机操作

  • 形式:单独完成
  • 题目:完成进程管理
  • 要求:按照讲课笔记完成显示进程、杀死进程与作业前后台切换任务

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1303134.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

go 编译apk

首先进行安装go 安装 wget https://studygolang.com/dl/golang/go1.21.5.linux-amd64.tar.gz tar zxvf go1.21.5.linux-amd64.tar.gz mv go /usr/local/ vim /etc/profile # 进行配置环境变量: export GOROOT/usr/local/go export PATH$PATH:$GOROOT/bin # 保存退…

算法Day28 二进制差异序列(格雷码)

二进制差异序列(格雷码) Description n 位二进制差异序列是一个由2^n个整数组成的序列,其中: 每个整数都在范围[0, 2^n - 1]内(含0和2^n - 1) 第一个整数是0 一个整数在序列中出现不超过一次 每对相邻整数…

LeetCode-1008. 前序遍历构造二叉搜索树【栈 树 二叉搜索树 数组 二叉树 单调栈】

LeetCode-1008. 前序遍历构造二叉搜索树【栈 树 二叉搜索树 数组 二叉树 单调栈】 题目描述:解题思路一:题目大致意思就是给定一个二叉树的前序遍历,求对应的二叉搜索树。一种比较特殊的点是「二叉搜索树」的中序遍历的结果是【有序序列】&am…

参数占位符#{}和${}

#是预处理而$是直接替换 Mybatis在处理#{}时,会将SQL中的#{}替换成占位符?,再使用preparedStatement的set方法来赋值。而Mybatis在处理 时,是将 {}时,是将 时,是将{}直接替换成变量的值 我们分别使用#{}和…

热电厂发电机组常见故障及预测性维护方法

热电厂的发电机组是关键的能源生产设备,在电力供应中扮演着关键角色。但经过长期运行和高负荷工作,一旦发生故障,可能导致停机、设备损坏甚至引发严重事故。因此,实施有效的预测性维护方法对于确保发电机组的稳定运行至关重要。本…

vue3封装接口

在src下面创建一个文件夹任意名称 我拿这个名字举例子了apiService 相当于创建一个新的文件 // 封装接口 // apiService.js import axios from axios;// 接口前缀 const API_BASE_URL 前缀;接口后缀export const registerUser async (fileData) > {try {const response …

Node CLI 之 Yargs (2)

什么是 yargs? yargs 是一个用于处理命令行参数的 Node.js 库 安装 yargs npm install yargs简单例子 不定义任何选项,直接便可以使用 定义命令 const yargs require(yargs)yargs.command(hello, Prints hello world, (yargs) > {}, (argv) >…

栈(深入理解栈是什么)

这里写目录标题 栈概念栈的初始化栈的溢出函数的栈帧函数的返回 栈 概念 英文:stack,也叫做堆栈。 特点:先进后出。 栈的两个基本操作,也就是入栈和出栈。都是通过SP指针来维护。C语言中的函数的局部变量,传递的实参…

datav-实现轮播表,使用updateRows方法-无缝衔接加载数据

前言 最近在做大屏需求的时候,遇到一个轮播数据的需求,查看datav文档发现确实有这个组件 但这个组件只提供了一次加载轮播的例子,虽然提供了轮播加载数据updateRows方法 但是文档并没有触发事件,比如轮播完数据触发事件&#xf…

RocketMQ-RocketMQ高性能核心原理节点(流程图)

NamesrvServer启动流程图: namesrvServer启动简图: Broker服务启动过程流程图 Broker服务启动过程流程简图 整体RPC框架流程如下图 client: DefaultMQProducer

CTF刷题记录

刷题 我的md5脏了KFC疯狂星期四坤坤的csgo邀请simplePHPcurl 我的md5脏了 g0at无意间发现了被打乱的flag:I{i?8Sms??Cd_1?T51??F_1?} 但是好像缺了不少东西,flag的md5值已经通过py交易得到了:88875458bdd87af5dd2e3c750e534741 flag…

2024美赛备战1--数据处理(数据预处理,异常值处理,预测模型,插值拟合 *****必看****)

1.数据预处理 所谓数据预处理,就是指在正式做题之前对数据进行的一些处理。在有些情 况下,出题方提供的数据或者网上查找的数据并不能直接使用,比如缺少数据甚 至是异常数据,如果直接忽略缺失值,或者没发现异常数据&am…

idea java 创建 hellword 项目

1.概要 建立一个最简单的工程,开始编码。 2.试验过程 2.1 创建的过程很简单,除了第一个窗口选择“java 模块”,其他的都是下一步。 2.2 还有就是刚创建的工程什么都没有需要,自己创建一个启动的类和启动函数。 2.3 运行和运行…

随机生成验证码的jar包

这是已经开发好的验证码,咱们直接调用接口,拿过来直接用就可以了 链接:https://pan.baidu.com/s/1QMPhW5UzxmhIa7THFab5hw 提取码:6666 下面演示一下: 首先创建一个Code来先生成随机验证码,然后传…

一个音乐能够做成二维码吗?音乐的活码制作技巧

一个音乐能够做成二维码后展示吗?现在以二维码为载体来储存内容的方式越来越常见,比如图片、文件、视频、音频都可以做成二维码展示,人们也更习惯去扫码获取内容。音频作为日常工作生活中常用的一种内容,可以用音频二维码生成器来…

如何在Word中简洁地插入代码

如何在Word中简洁地插入代码 背景: ​ 最近在一写一些论文或者报告的时候,需要将源代码放在论文的最后,有一个很头疼的问题,如果直接把代码从编辑器复制到word中,就变成了下面这个样子: 这有点丑陋啊&…

2023-12学习笔记

1.NonNull要手动写无参构造器 这是一个我今天研究了很久的问题,开始不知道原因是在这里,还在那想是不是Data覆盖了无参构造,结果当然不是。先说下解决历程 1.问题起因 通过RequestBody接收前端报文的时候报错,大致是说我构造方…

【算法提升—力扣每日一刷】五日总结【12/06--12/10】

2023/12/06 力扣每日一刷:206. 反转链表 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 示例 1: 输入:head [1,2,3,4,5] 输出:[5,4,3,2,1]示例 2: 输入:head [1,2…

马云说的AI电商真的要来了?AR技术虚拟试穿公司ZERO10引入AI人工智能模型,未来试衣间就应这样!

ZERO10 是一家提供虚拟试穿体验的公司,他们基于自家的 AR 技术,提供高度逼真且顶尖的虚拟试穿体验。与现有的技术不同,他们的生成式人工智能试穿技术只需要 1-5 张用户照片,就可以实现虚拟试穿。这种方法为规模化应用提供了巨大机…

jquery手写广告轮播图,无限循环功能

说明 在很多情况下,我们都需要开发广告轮播图,当我们进行页面的功能开发时,采用轮播图来实现也行,但是很多情况下,我们只需要简单的控制轮播循环轮播展示即可,所以用jq开开发广告轮播波,自定义…