系統(tǒng)之家 - 系統(tǒng)光盤下載網(wǎng)站!

當(dāng)前位置:系統(tǒng)之家 > 系統(tǒng)教程 > Linux進程關(guān)系

Linux系統(tǒng)中進程相互之間有哪些關(guān)系?

時間:2014-12-16 15:22:14 作者:qipeng 來源:系統(tǒng)之家 1. 掃描二維碼隨時看資訊 2. 請使用手機瀏覽器訪問: https://m.xitongzhijia.net/xtjc/20141216/32693.html 手機查看 評論

  作為Linux系統(tǒng)管理員,為了更好的管理進程,就有必要對進程之間的關(guān)系有個詳細的了解,下面小編就給大家介紹下Linux進程之間的關(guān)系,一起來學(xué)習(xí)下吧。

  Linux的進程相互之間有一定的關(guān)系。比如說,在Linux進程基礎(chǔ)中,我們看到,每個進程都有父進程,而所有的進程以init進程為根,形成一個樹狀結(jié)構(gòu)。我們在這里講解進程組和會話,以便以更加豐富的方式了管理進程。

  進程組 (process group)

  每個進程都會屬于一個進程組(process group),每個進程組中可以包含多個進程。進程組會有一個進程組領(lǐng)導(dǎo)進程 (process group leader),領(lǐng)導(dǎo)進程的PID (PID見Linux進程基礎(chǔ))成為進程組的ID (process group ID, PGID),以識別進程組。

  代碼如下:

  $ps -o pid,pgid,ppid,comm | cat《/p》 《p》 PID PGID PPID COMMAND

  17763 17763 17751 bash

  18534 18534 17763 ps

  18535 18534 17763 cat

  PID為進程自身的ID,PGID為進程所在的進程組的ID, PPID為進程的父進程ID。從上面的結(jié)果,我們可以推測出如下關(guān)系:

   Linux系統(tǒng)中進程相互之間有哪些關(guān)系?

  圖中箭頭表示父進程通過fork和exec機制產(chǎn)生子進程。ps和cat都是bash的子進程。進程組的領(lǐng)導(dǎo)進程的PID成為進程組ID。領(lǐng)導(dǎo)進程可以先終結(jié)。此時進程組依然存在,并持有相同的PGID,直到進程組中最后一個進程終結(jié)。

  我們將一些進程歸為進程組的一個重要原因是我們可以將信號發(fā)送給一個進程組。進程組中的所有進程都會收到該信號。我們會在下一部分深入討論這一點。

  會話 (session)

  更進一步,在shell支持工作控制(job control)的前提下,多個進程組還可以構(gòu)成一個會話 (session)。bash(Bourne-Again shell)支持工作控制,而sh(Bourne shell)并不支持。

  會話是由其中的進程建立的,該進程叫做會話的領(lǐng)導(dǎo)進程(session leader)。會話領(lǐng)導(dǎo)進程的PID成為識別會話的SID(session ID)。會話中的每個進程組稱為一個工作(job)。會話可以有一個進程組成為會話的前臺工作(foreground),而其他的進程組是后臺工作(background)。每個會話可以連接一個控制終端(control terminal)。當(dāng)控制終端有輸入輸出時,都傳遞給該會話的前臺進程組。由終端產(chǎn)生的信號,比如CTRL+Z, CTRL+\,會傳遞到前臺進程組。

  會話的意義在于將多個工作囊括在一個終端,并取其中的一個工作作為前臺,來直接接收該終端的輸入輸出以及終端信號。 其他工作在后臺運行。

  一個命令可以通過在末尾加上&方式讓它在后臺運行:

  代碼如下:

  $ping localhost 》 log &

  此時終端顯示:

  代碼如下:

 。1] 10141

  括號中的1表示工作號,而10141為PGID

  我們通過如下方式查詢更加詳細的信息:

  代碼如下:

  $ps -o pid,pgid,ppid,sid,tty,comm

 。╰ty表示控制終端)

  信號可以通過kill

  代碼如下:

  $kill -SIGTERM -10141

  或者

  代碼如下:

  $kill -SIGTERM %1

  的方式來發(fā)送給工作組。上面的兩個命令,一個是發(fā)送給PGID(通過在PGID前面加-來表示是一個PGID而不是PID),一個是發(fā)送給工作1(%1),兩者等價。

  一個工作可以通過$fg從后臺工作變?yōu)榍芭_工作:

  代碼如下:

  $cat 》 log &

  $fg %1

  當(dāng)我們運行第一個命令后,由于工作在后臺,我們無法對命令進行輸入,直到我們將工作帶入前臺,才能向cat命令輸入。在輸入完成后,按下CTRL+D來通知shell輸入結(jié)束。

  進程組(工作)的概念較為簡單易懂。而會話主要是針對一個終端建立的。當(dāng)我們打開多個終端窗口時,實際上就創(chuàng)建了多個終端會話。每個會話都會有自己的前臺工作和后臺工作。這樣,我們就為進程增加了管理和運行的層次。在沒有圖形化界面的時代,會話允許用戶通過shell進行多層次的進程發(fā)起和管理。比如說,我可以通過shell發(fā)起多個后臺工作,而此時標準輸入輸出并不被占據(jù),我依然可以繼續(xù)其它的工作。如今,圖形化界面可以幫助我們解決這一需求,但工作組和會話機制依然在Linux的許多地方應(yīng)用。

  總結(jié)

  process group, pgid

  session, sid, job, forground, background

  fg, kill -pid, &, %

  上面就是Linux進程之間的關(guān)系介紹了,其實進程之間是有一定的聯(lián)系的,每個進程都會屬于一個進程組,你對進程之間的關(guān)系有一定的了解了嗎?

發(fā)表評論

0

沒有更多評論了

評論就這些咯,讓大家也知道你的獨特見解

立即評論

以上留言僅代表用戶個人觀點,不代表系統(tǒng)之家立場

其他版本軟件

熱門教程

人氣教程排行

Linux系統(tǒng)推薦

掃碼關(guān)注
掃碼關(guān)注

掃碼關(guān)注 官方交流群 軟件收錄