欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Linux進(jìn)程通信(IPC)方式簡(jiǎn)介

 更新時(shí)間:2013年12月08日 10:18:04   作者:  
linux下進(jìn)程間通信的幾種主要方式:管道(pipe)和有名管道(FIFO)、信號(hào)(signal)、消息隊(duì)列、共享內(nèi)存(shared memory)、信號(hào)量(semaphore)、套接字(socket),本文對(duì)這些做簡(jiǎn)單介紹

進(jìn)程間通信的目的

數(shù)據(jù)傳輸:一個(gè)進(jìn)程需要將它的數(shù)據(jù)發(fā)送給另一個(gè)進(jìn)程,發(fā)送的數(shù)據(jù)量在一個(gè)字節(jié)到幾兆字節(jié)之間。
共享數(shù)據(jù):多個(gè)進(jìn)程想要操作共享數(shù)據(jù),一個(gè)進(jìn)程對(duì)共享數(shù)據(jù)的修改,別的進(jìn)程應(yīng)該立刻看到。
通知事件:一個(gè)進(jìn)程需要向另一個(gè)或一組進(jìn)程發(fā)送消息,通知它(它們)發(fā)生了某種事件(如進(jìn)程終止時(shí)要通知父進(jìn)程)。
資源共享:多個(gè)進(jìn)程之間共享同樣的資源。為了作到這一點(diǎn),需要內(nèi)核提供鎖和同步機(jī)制。
進(jìn)程控制:有些進(jìn)程希望完全控制另一個(gè)進(jìn)程的執(zhí)行(如Debug進(jìn)程),此時(shí)控制進(jìn)程希望能夠攔截另一個(gè)進(jìn)程的所有陷入和異常,并能夠及時(shí)知道它的狀態(tài)改變。

進(jìn)程通信方式

linux下進(jìn)程間通信的幾種主要方式:

(1)管道(pipe)和有名管道(FIFO)
(2)信號(hào)(signal)
(3)消息隊(duì)列
(4)共享內(nèi)存(shared memory)
(5)信號(hào)量(semaphore)
(6)套接字(socket)

管道

管道(pipe)及有名管道(named pipe):管道可用于具有親緣關(guān)系進(jìn)程間的通信,有名管道克服了管道沒(méi)有名字的限制,因此,除具有管道所具有的功能外,它還允許無(wú)親緣關(guān)系進(jìn)程間的通信。
管道是單向的、先進(jìn)先出的、無(wú)結(jié)構(gòu)的、固定大小的字節(jié)流,它把一個(gè)進(jìn)程的標(biāo)準(zhǔn)輸出和另一個(gè)進(jìn)程的標(biāo)準(zhǔn)輸入連接在一起。寫(xiě)進(jìn)程在管道的尾端寫(xiě)入數(shù)據(jù),讀進(jìn)程在管道的首端讀出數(shù)據(jù)。數(shù)據(jù)讀出后將從管道中移走,其它讀進(jìn)程都不能再讀到這些數(shù)據(jù)。管道提供了簡(jiǎn)單的流控制機(jī)制。進(jìn)程試圖讀空管道時(shí),在有數(shù)據(jù)寫(xiě)入管道前,進(jìn)程將一直阻塞。同樣,管道已經(jīng)滿(mǎn)時(shí),進(jìn)程再試圖寫(xiě)管道,在其它進(jìn)程從管道中移走數(shù)據(jù)之前,寫(xiě)進(jìn)程將一直阻塞。通常有種限制,一是半雙工,只能單向傳輸;二是只能在父子進(jìn)程間使用。
有名管道(也叫FIFO,因?yàn)楣艿拦ぷ髟谙热胂瘸龅脑瓌t下,第一個(gè)寫(xiě)入管道的數(shù)據(jù)也是第一個(gè)被讀出的數(shù)據(jù))。與管道不同,F(xiàn)IFO不是臨時(shí)的對(duì)象,它們是文件系統(tǒng)中真正的實(shí)體,可以用mkfifo命令創(chuàng)建。只要有合適的訪(fǎng)問(wèn)權(quán)限,進(jìn)程就可以使用FIFO。FIFO的打開(kāi)方式和管道稍微不同。一個(gè)管道(它的兩個(gè)file數(shù)據(jù)結(jié)構(gòu)、VFS I節(jié)點(diǎn)和共享數(shù)據(jù)頁(yè))是一次性創(chuàng)建的,而FIFO已經(jīng)存在,可以由它的用戶(hù)打開(kāi)和關(guān)閉。Linux必須處理在寫(xiě)進(jìn)程打開(kāi)FIFO之前讀進(jìn)程對(duì)它的打開(kāi),也必須處理在寫(xiě)進(jìn)程寫(xiě)數(shù)據(jù)之前讀進(jìn)程對(duì)管道的讀。除此以外,F(xiàn)IFO幾乎和管道的處理完全一樣,而且它們使用一樣的數(shù)據(jù)結(jié)構(gòu)和操作。

信號(hào)

信號(hào)(signal):信號(hào)是比較復(fù)雜的通信方式,用于通知接受進(jìn)程有某種事件發(fā)生,除了用于進(jìn)程間通信外,進(jìn)程還可以發(fā)送信號(hào)給進(jìn)程本身;linux除了支持Unix早期信號(hào)語(yǔ)義函數(shù)sigal外,還支持語(yǔ)義符合Posix.1標(biāo)準(zhǔn)的信號(hào)函數(shù)sigaction(實(shí)際上,該函數(shù)是基于BSD的,BSD為了實(shí)現(xiàn)可靠信號(hào)機(jī)制,又能夠統(tǒng)一對(duì)外接口,用sigaction函數(shù)重新實(shí)現(xiàn)了signal函數(shù))。
信號(hào)是在軟件層次上對(duì)中斷機(jī)制的一種模擬,是一種異步通信方式。
信號(hào)可以直接進(jìn)行用戶(hù)空間進(jìn)程和內(nèi)核進(jìn)程之間的交互,內(nèi)核進(jìn)程也可以利用它來(lái)通知用戶(hù)空間進(jìn)程發(fā)生了哪些系統(tǒng)事件。它可以在任何時(shí)候發(fā)給某一進(jìn)程,而無(wú)需知道該進(jìn)程的狀態(tài)。
如果該進(jìn)程當(dāng)前并未處于執(zhí)行態(tài),則該信號(hào)就由內(nèi)核保存起來(lái),直到該進(jìn)程恢復(fù)執(zhí)行再傳遞給它;如果一個(gè)信號(hào)被進(jìn)程設(shè)置為阻塞,則該信號(hào)的傳遞被延遲,直到其阻塞被取消時(shí)才被傳遞給進(jìn)程 。

進(jìn)程執(zhí)行信號(hào)的方式:
忽略信號(hào),即對(duì)信號(hào)不做任何處理,其中,有兩個(gè)信號(hào)不能忽略:SIGKILL及SIGSTOP。
捕捉信號(hào),定義信號(hào)處理函數(shù),當(dāng)信號(hào)發(fā)生時(shí),執(zhí)行相應(yīng)的處理函數(shù)。
執(zhí)行缺省操作,Linux對(duì)每種信號(hào)都規(guī)定了默認(rèn)操作。

消息隊(duì)列

消息隊(duì)列:消息隊(duì)列是消息的鏈接表,包括Posix消息隊(duì)列System V消息隊(duì)列。有足夠權(quán)限的進(jìn)程可以向隊(duì)列中添加消息,被賦予讀權(quán)限的進(jìn)程則可以讀走隊(duì)列中的消息。消息隊(duì)列克服了信號(hào)承載信息量少,管道只能承載無(wú)格式字節(jié)流以及緩沖區(qū)大小受限等缺點(diǎn)。
消息隊(duì)列的實(shí)現(xiàn)包括創(chuàng)建或打開(kāi)消息隊(duì)列、添加消息、讀取消息和控制消息隊(duì)列這四種操作:
創(chuàng)建或打開(kāi)消息隊(duì)列使用的函數(shù)是msgget,這里創(chuàng)建的消息隊(duì)列的數(shù)量會(huì)受到系統(tǒng)消息隊(duì)列數(shù)量的限制。
添加消息使用的函數(shù)是msgsnd函數(shù),它把消息添加到已打開(kāi)的消息隊(duì)列末尾。
讀取消息使用的函數(shù)是msgrcv,它把消息從消息隊(duì)列中取走,與FIFO不同的是,這里可以指定取走某一條消息。
控制消息隊(duì)列使用的函數(shù)是msgctl,它可以完成多項(xiàng)功能。

信號(hào)量/信號(hào)燈

信號(hào)量(semaphore):主要作為進(jìn)程間以及同一進(jìn)程不同線(xiàn)程之間的同步手段。信號(hào)量是用來(lái)解決進(jìn)程之間的同步與互斥問(wèn)題的一種進(jìn)程之間通信機(jī)制,包括一個(gè)稱(chēng)為信號(hào)量的變量和在該信號(hào)量下等待資源的進(jìn)程等待隊(duì)列,以及對(duì)信號(hào)量進(jìn)行的兩個(gè)原子操作(PV操作)。其中信號(hào)量對(duì)應(yīng)于某一種資源,取一個(gè)非負(fù)的整型值。信號(hào)量值指的是當(dāng)前可用的該資源的數(shù)量,若它等于0則意味著目前沒(méi)有可用的資源。

P操作:如果有可用的資源(信號(hào)量值>0),則占用一個(gè)資源(給信號(hào)量值減去一,進(jìn)入臨界區(qū)代碼)。如果沒(méi)有可用的資源(信號(hào)量值等于0),則被阻塞到,直到系統(tǒng)將資源分配給該進(jìn)程(進(jìn)入等待隊(duì)列,一直等到資源輪到該進(jìn)程)。
V操作:如果在該信號(hào)量的等待隊(duì)列中有進(jìn)程在等待資源,則喚醒一個(gè)阻塞進(jìn)程。如果沒(méi)有進(jìn)程等待它,則釋放一個(gè)資源(給信號(hào)量值加一)。

共享內(nèi)存

共享內(nèi)存(shared memory)可以說(shuō)是最有用的進(jìn)程間通信方式,也是最快的IPC形式。兩個(gè)不同進(jìn)程A、B共享內(nèi)存的意思是,同一塊物理內(nèi)存被映射到進(jìn)程A、B各自的進(jìn)程地址空間。進(jìn)程A可以即時(shí)看到進(jìn)程B對(duì)共享內(nèi)存中數(shù)據(jù)的更新,反之亦然。由于多個(gè)進(jìn)程共享同一塊內(nèi)存區(qū)域,必然需要某種同步機(jī)制,互斥鎖和信號(hào)量都可以。

采用共享內(nèi)存通信的一個(gè)顯而易見(jiàn)的好處是效率高,因?yàn)檫M(jìn)程可以直接讀寫(xiě)內(nèi)存,而不需要任何數(shù)據(jù)的拷貝。對(duì)于像管道和消息隊(duì)列等通信方式,則需要在內(nèi)核和用戶(hù)空間進(jìn)行四次的數(shù)據(jù)拷貝,而共享內(nèi)存則只拷貝兩次數(shù)據(jù):一次從輸入文件到共享內(nèi)存區(qū),另一次從共享內(nèi)存區(qū)到輸出文件。實(shí)際上,進(jìn)程之間在共享內(nèi)存時(shí),并不總是讀寫(xiě)少量數(shù)據(jù)后就解除映射,有新的通信時(shí),再重新建立共享內(nèi)存區(qū)域。而是保持共享區(qū)域,直到通信完畢為止,這樣,數(shù)據(jù)內(nèi)容一直保存在共享內(nèi)存中,并沒(méi)有寫(xiě)回文件。共享內(nèi)存中的內(nèi)容往往是在解除映射時(shí)才寫(xiě)回文件的。因此,采用共享內(nèi)存的通信方式效率是非常高的。

共享內(nèi)存實(shí)現(xiàn)的步驟:
1.創(chuàng)建共享內(nèi)存,這里用到的函數(shù)是shmget,也就是從內(nèi)存中獲得一段共享內(nèi)存區(qū)域。
2.映射共享內(nèi)存,也就是把這段創(chuàng)建的共享內(nèi)存映射到具體的進(jìn)程空間中去,這里使用的函數(shù)是shmat。
3.使用不帶緩沖的I/O讀寫(xiě)命令對(duì)其進(jìn)行操作。
4.撤銷(xiāo)映射的操作,其函數(shù)為shmdt。

套接口

套接口(socket):更為一般的進(jìn)程間通信機(jī)制,可用于不同機(jī)器之間的進(jìn)程間通信。起初是由Unix系統(tǒng)的BSD分支開(kāi)發(fā)出來(lái)的,但現(xiàn)在一般可以移植到其它類(lèi)Unix系統(tǒng)上:Linux和System V的變種都支持套接字。

相關(guān)文章

  • shell腳本引用外部變量的兩種方法

    shell腳本引用外部變量的兩種方法

    本文主要介紹了shell腳本引用外部變量的兩種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Shell最多支持多少個(gè)參數(shù)?

    Shell最多支持多少個(gè)參數(shù)?

    這篇文章主要介紹了Shell最多支持多少個(gè)參數(shù)?本文是對(duì)Shell最多可以輸入多少個(gè)參數(shù)的一篇測(cè)試文章,需要的朋友可以參考下
    2014-10-10
  • linux 下獲取當(dāng)前工作路徑的實(shí)例

    linux 下獲取當(dāng)前工作路徑的實(shí)例

    今天小編就為大家分享一篇linux 下獲取當(dāng)前工作路徑的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-06-06
  • Shell正則表達(dá)式學(xué)習(xí)筆記

    Shell正則表達(dá)式學(xué)習(xí)筆記

    正則表達(dá)式是一種表示方式,可以讓你查找匹配特定的準(zhǔn)則的文本,例如以字母a開(kāi)頭的文件,學(xué)好正則表達(dá)式將使以后的文本處理變得方便,快速,本文給大家介紹shell正則表達(dá)式學(xué)習(xí)筆記,對(duì)shell正則表達(dá)式相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧
    2015-12-12
  • 詳解shell 函數(shù)定義與調(diào)用

    詳解shell 函數(shù)定義與調(diào)用

    這篇文章主要介紹了shell 函數(shù)定義與調(diào)用的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)shell,感興趣的朋友可以了解下
    2020-09-09
  • mysql源碼安裝腳本分享

    mysql源碼安裝腳本分享

    這篇文章主要介紹了mysql源碼安裝的腳本,配置文件的內(nèi)容是針對(duì)mysql5.6的,需要的朋友可以參考下
    2014-03-03
  • Shell腳本搭建FTP服務(wù)器(vsftpd)

    Shell腳本搭建FTP服務(wù)器(vsftpd)

    這篇文章主要介紹了Shell腳本搭建FTP服務(wù)器,本文直接給出腳本代碼,代碼中含有詳細(xì)注釋,需要的朋友可以參考下
    2015-03-03
  • shell 遞歸遍歷目錄下的所有文件并統(tǒng)一改名的方法

    shell 遞歸遍歷目錄下的所有文件并統(tǒng)一改名的方法

    今天小編就為大家分享一篇shell 遞歸遍歷目錄下的所有文件并統(tǒng)一改名的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-06-06
  • 淺談Shell中的函數(shù)

    淺談Shell中的函數(shù)

    這篇文章主要介紹了Shell中函數(shù)的相關(guān)資料,幫助大家更好的理解和使用shell,感興趣的朋友可以了解下
    2020-09-09
  • Linux下rm誤刪除文件的三種恢復(fù)方法

    Linux下rm誤刪除文件的三種恢復(fù)方法

    一下午寫(xiě)的程序就被rm掉了,幸好只是一個(gè)文件,第二天很快又重新寫(xiě)了一遍。但是很多人可能就不像我這么幸運(yùn)了,本文收集了一些在Linux下恢復(fù)rm刪除的文件的方法,需要的朋友可以參考下
    2022-12-12

最新評(píng)論