作為Linux系統管理員,為了更好的管理進程,就有必要對進程之間的關系有個詳細的了解,下面小編就給大家介紹下Linux進程之間的關系,一起來學習下吧。
Linux的進程相互之間有一定的關系。比如說,在Linux進程基礎中,我們看到,每個進程都有父進程,而所有的進程以init進程為根,形成一個樹狀結構。我們在這裡講解進程組和會話,以便以更加豐富的方式了管理進程。
進程組 (process group)
每個進程都會屬於一個進程組(process group),每個進程組中可以包含多個進程。進程組會有一個進程組領導進程 (process group leader),領導進程的PID (PID見Linux進程基礎)成為進程組的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。從上面的結果,我們可以推測出如下關系:
圖中箭頭表示父進程通過fork和exec機制產生子進程。ps和cat都是bash的子進程。進程組的領導進程的PID成為進程組ID。領導進程可以先終結。此時進程組依然存在,並持有相同的PGID,直到進程組中最後一個進程終結。
我們將一些進程歸為進程組的一個重要原因是我們可以將信號發送給一個進程組。進程組中的所有進程都會收到該信號。我們會在下一部分深入討論這一點。
會話 (session)
更進一步,在shell支持工作控制(job control)的前提下,多個進程組還可以構成一個會話 (session)。bash(Bourne-Again shell)支持工作控制,而sh(Bourne shell)並不支持。
會話是由其中的進程建立的,該進程叫做會話的領導進程(session leader)。會話領導進程的PID成為識別會話的SID(session ID)。會話中的每個進程組稱為一個工作(job)。會話可以有一個進程組成為會話的前台工作(foreground),而其他的進程組是後台工作(background)。每個會話可以連接一個控制終端(control terminal)。當控制終端有輸入輸出時,都傳遞給該會話的前台進程組。由終端產生的信號,比如CTRL+Z, CTRL+\,會傳遞到前台進程組。
會話的意義在於將多個工作囊括在一個終端,並取其中的一個工作作為前台,來直接接收該終端的輸入輸出以及終端信號。 其他工作在後台運行。
一個命令可以通過在末尾加上&方式讓它在後台運行:
代碼如下:
$ping localhost 》 log &
此時終端顯示:
代碼如下:
[1] 10141
括號中的1表示工作號,而10141為PGID
我們通過如下方式查詢更加詳細的信息:
代碼如下:
$ps -o pid,pgid,ppid,sid,tty,comm
(tty表示控制終端)
信號可以通過kill
代碼如下:
$kill -SIGTERM -10141
或者
代碼如下:
$kill -SIGTERM %1
的方式來發送給工作組。上面的兩個命令,一個是發送給PGID(通過在PGID前面加-來表示是一個PGID而不是PID),一個是發送給工作1(%1),兩者等價。
一個工作可以通過$fg從後台工作變為前台工作:
代碼如下:
$cat 》 log &
$fg %1
當我們運行第一個命令後,由於工作在後台,我們無法對命令進行輸入,直到我們將工作帶入前台,才能向cat命令輸入。在輸入完成後,按下CTRL+D來通知shell輸入結束。
進程組(工作)的概念較為簡單易懂。而會話主要是針對一個終端建立的。當我們打開多個終端窗口時,實際上就創建了多個終端會話。每個會話都會有自己的前台工作和後台工作。這樣,我們就為進程增加了管理和運行的層次。在沒有圖形化界面的時代,會話允許用戶通過shell進行多層次的進程發起和管理。比如說,我可以通過shell發起多個後台工作,而此時標准輸入輸出並不被占據,我依然可以繼續其它的工作。如今,圖形化界面可以幫助我們解決這一需求,但工作組和會話機制依然在Linux的許多地方應用。
總結
process group, pgid
session, sid, job, forground, background
fg, kill -pid, &, %
上面就是Linux進程之間的關系介紹了,其實進程之間是有一定的聯系的,每個進程都會屬於一個進程組,你對進程之間的關系有一定的了解了嗎?