进程组、作业、会话的概念梳理

1.进程组

基本概念

进程组就是一些进程的组合。这些进程并不是孤立的,他们彼此之间或者存在父子、兄弟关系,或者在功能上有相近的联系。

作用

为啥Linux里要有进程组呢?其实,提供进程组就是为了方便对进程进行管理。假设要完成一个任务,需要同时并发100个进程。当用户处于某种原因要终止这个任务时,要是没有进程组,就需要手动的一个个去杀死这100个进程,并且必须要严格按照进程间父子兄弟关系顺序,否则会扰乱进程树。有了进程组,就可以将这100个进程设置为一个进程组,它们共有1个组号(pgid),并且有选取一个进程作为组长(通常是“辈分”最高的那个,通常该进程的ID也就作为进程组的ID)。现在就可以通过杀死整个进程组,来关闭这100个进程,并且是严格有序的。

属性及约束

进程必定属于一个进程组,也只能属于一个进程组。 一个进程组中可以包含多个进程。 进程组的生命周期从被创建开始,到其内所有进程终止或离开该组。组长进程可以创建一个进程组,创建该组中的进程,然后终止。只要在某个进程组中一个进程存在,则该进程组就存在,这与其组长进程是否终止无关。每个进程组有一个唯一的进程组ID。每个进程组都可以有一个组长进程。组长进程的标识是,其进程组ID等于其进程ID。Fork()函数并不改变子进程的进程组id。

产生

Shell 上的一条命令行形成一个进程组 ,shell管道有时也产生进程组  ps -ef | grep root 。当使用管道线时,如echo "hello" | cat,bash以第一个命令的进程ID为该管道线内所有进程设置进程组ID。

通常,进程组与同一作业相关联。如果进程组中的某个进程又fork出子进程,子进程也属于同一进程组,但是Shell并不知道子进程的存在,也不会调用wait等待它结束。换句话说,原来的进程组是Shell的作业,而这个子进程不是,这是作业和进程组在概念上的区别。

2.会话

基本概念

一次用户的登录(并取得控制台)形成一个会话,一个会话中有多个进程组,有一个或0个前台前程,有N个后台进程。

作用

由于Linux是多用户多任务的分时系统,所以必须要支持多个用户同时使用一个操作系统。当一个用户登录一次系统就形成一次会话。每个会话都有一个会话首领(leader),即创建会话的进程。

属性及约束

一个会话可包含多个进程组,但只能有一个前台进程组,可能有也可能没有控制终端。前台进程组中的进程能够向终端设备进行读、写操作。后台进程组是一个会话中,除前台进程组、会话首进程以外的所有进程组。该进程组中的进程能够向终端设备写,但是当试图读终端设备时,将会收到SIGTTIN信号,并停止。登录shell可以根据设置在终端上发出一条消息[1]通知用户有进程欲求读终端。

产生

使用setsid 可建立一个新的会话,如果调用进程不是进程组的领头进程,该函数才能建立新的会话。调用setsid之后,进程成为新会话的领头进程、进程成为新进程组的领头进程、进程失去控制终端(可以为这个新会话关联一个新的终端)。

会话的领头进程打开一个终端之后, 该终端就成为该会话的控制终端(SVR4/Linux) ,与控制终端建立连接的会话领头进程称为会话首进程(session leader)。一个会话只能有一个控制终端 。产生在控制终端上的输入和信号将发送给会话的前台进程组中的所有进程。终端上的连接断开时(比如网络断开或 Modem 断开),挂起信号将发送到会话首进程(session leader)(进而会使得所有进程组退出)。

实例说明

Shell进程本身属于一个单独的进程组,在没有运行命令时,他也是前台进程组。

登陆shell(例如bash)通过调用tcsetpgrp()函数设置前台进程组(这就是shell运行程序的步骤之一),该函数将终端设备的fd(文件描述符)与指定进程组关联。具体的过程是:由Shell进程fork出的子进程本来具有和Shell相同的Session、进程组和控制终端,但是Shell调用setpgid函数将作业中的某个子进程指定为一个新进程组的Leader,然后调用setpgid将该作业中的其它子进程也转移到这个进程组中。如果这个进程组需要在前台运行,就调用 tcsetpgrp函数将它设置为前台进程组,由于一个Session只能有一个前台进程组,所以Shell所在的进程组就自动变成后台进程组。一旦作业运行结束,Shell就把自己提到前台,如果原来的前台进程组还存在(如果这个子进程还没终止),则它自动变成后台进程组。

成为前台进程组的进程其TPGID=PGID,常常可以通过比较他们来判断前后台进程组。

Ctrl+c是把信号送给了前台进程组的所有进程。


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值