• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 40, 文章 - 0, 評(píng)論 - 9, 引用 - 0
            數(shù)據(jù)加載中……

            進(jìn)程間通訊簡(jiǎn)介

            http://bbs.chinaunix.net/viewthread.php?tid=1130381

             所謂進(jìn)程間通訊,顧名思義,就是在2個(gè)(多數(shù)情況下)或多個(gè)進(jìn)程間傳遞信息。方法大致如下幾種:
                 1,  文件(file),匿名管道(anonymous pipe),命名管道(named pipe),信號(hào)(signal).
                     2、  System V IPC 包括消息隊(duì)列(message queue),共享內(nèi)存(shared memory),信號(hào)量(semaphore)。這種形式的ipc首先在UNIX分支system V中使用,現(xiàn)在多數(shù)unix系統(tǒng)都支持。
            文件形式的IPC:

            進(jìn)程(process) A寫(xiě)信息到文件1,進(jìn)程B讀文件1。文件的內(nèi)容,由進(jìn)程自己決定。
            匿名管道:

            command1 args1 | command2 args2. 最常見(jiàn)的例子:ls –l |more 由于管道操作由shell代替完成,沒(méi)有產(chǎn)生有名字的實(shí)體,所以稱(chēng)為匿名管道。 Shell做的事情是調(diào)用pipe(),產(chǎn)生一個(gè)管道,然后把command1的輸出連接到管道的出入端,把command2的輸入連接到管道的輸出端。
            命名管道

            首先,建立一個(gè)特殊文件,mkfifo pipe1或者mknod fifo1 p
            然后,就當(dāng)作正常文件讀寫(xiě)pipe1。例如: ls > fifo1 (寫(xiě)入)。
            while read a
            do
               echo $a
            done    (讀出)
            由于產(chǎn)生有名字的實(shí)體,所以被稱(chēng)為命名管道。
            信號(hào):

            簡(jiǎn)單的用法: kill –USER2 pid,也就是通過(guò)kill()系統(tǒng)調(diào)用或者kill命令,發(fā)送信號(hào)到別的進(jìn)程。各個(gè)進(jìn)程對(duì)于信號(hào)的處理過(guò)程是自己定義的(除了9,也就是KILL是強(qiáng)制 的)。比如自己可以忽略HUP,TERM,INT(按control-C), 等。
            消息隊(duì)列(message queue)

            消息隊(duì)列,是一個(gè)隊(duì)列的結(jié)構(gòu),隊(duì)列里面的內(nèi)容由用戶(hù)進(jìn)程自己定義。實(shí)際上,隊(duì)列里面記錄的是指向用戶(hù)自定義結(jié)構(gòu)的指針和結(jié)構(gòu)的大小。要使用message queue,首先要通過(guò)系統(tǒng)調(diào)用(msgget)產(chǎn)生一個(gè)隊(duì)列,然后,進(jìn)程可以用msgsnd發(fā)送消息到這個(gè)隊(duì)列,消息就是如上所說(shuō)的結(jié)構(gòu)。別的進(jìn)程用 msgrcv讀取。消息隊(duì)列一旦產(chǎn)生,除非明確的刪除(某個(gè)有權(quán)限的進(jìn)程或者用ipcrm命令)或者系統(tǒng)重啟。否則,產(chǎn)生的隊(duì)列會(huì)一直保留在系統(tǒng)中。而 且,只要有權(quán)限,就可以對(duì)隊(duì)列進(jìn)行操作。消息隊(duì)列和管道很相似,實(shí)際上,管道就是用戶(hù)消息為1個(gè)字節(jié)的隊(duì)列。
            ipcs –aq命令可以查看message queue的狀況:
            Message Queues:
            T      ID        KEY    MODE         OWNER    GROUP  CREATOR   CGROUP CBYTES  QNUM QBYTES  LSPID  LRPID  STIME    RTIME    CTIME
            q     256 0x417d0896 --rw-------      root   daemon     root   daemon      0     0  16384  97737 210466 14:31:14 14:31:14  9:52:53
            其中:
            T: 類(lèi)型, q 表明這是個(gè)消息隊(duì)列
            ID: 用戶(hù)自己定義的,在調(diào)用msgget時(shí)傳送的參數(shù)。
            Key: 系統(tǒng)返還的全局唯一的ID。
            Mode: 權(quán)限,含義和文件權(quán)限基本一致
            Owner, group: 隊(duì)列建立者的名字和組
            CREATOR, CGROUP:隊(duì)列建立者和組的ID
            CBYTES : 目前queue在隊(duì)列里的字節(jié)數(shù)
            QNUM, 目前queue在隊(duì)列里的消息數(shù)
            QBYTES: 隊(duì)列中消息最大允許字節(jié)數(shù)
            LSPID: 最后發(fā)送者PID
            LRPID: 最后接受者PID
            STIME: 最后發(fā)送時(shí)間
            RTIME: 最后接受時(shí)間。.
            CTIME: 建立或者最后修改的時(shí)間
            共享內(nèi)存(shared memory)

            共享內(nèi)存是一段可以被多個(gè)進(jìn)程共享的內(nèi)存段。首先,用shmget系統(tǒng)調(diào)用產(chǎn)生指定大小的共享內(nèi)存段,然后需要訪(fǎng)問(wèn)此共享內(nèi)存的進(jìn)程調(diào)用shmat系統(tǒng)調(diào) 用,把這個(gè)內(nèi)存段附加到自己的地址空間,然后就可以像訪(fǎng)問(wèn)自己私有的內(nèi)存一樣訪(fǎng)問(wèn)這個(gè)內(nèi)存段了。等到訪(fǎng)問(wèn)完畢,用shmdt脫離。同message queue一樣,共享內(nèi)存一旦產(chǎn)生,除非明確的刪除(某個(gè)有權(quán)限的進(jìn)程或者用ipcrm命令)或者系統(tǒng)重啟。否則,產(chǎn)生的共享內(nèi)存會(huì)一直保留在系統(tǒng)中。而 且,只要有權(quán)限,就可以對(duì)共享內(nèi)存進(jìn)行操作。共享內(nèi)存的內(nèi)容由進(jìn)程自己定義。為了防止多個(gè)進(jìn)程在同一時(shí)間寫(xiě)同樣一段共享內(nèi)存,一般程序會(huì)使用信號(hào)量來(lái)控制 對(duì)某一段地址的讀寫(xiě)。
            ipcs –am命令可以查看share memory的狀況:
            Shared Memory:
            T      ID        KEY    MODE         OWNER    GROUP  CREATOR   CGROUP NATTCH                SEGSZ   CPID   LPID   ATIME    DTIME    CTIME
            m     258          0 --rw-r-----    oracle      dba   oracle      dba     12              8388608 106303 106329 16:28:54 16:48:36 16:28:49
            T: 類(lèi)型 m 表明這是個(gè)共享內(nèi)存
            ID: 用戶(hù)自己定義的,在調(diào)用shmget時(shí)傳送的參數(shù)。
            Key: 系統(tǒng)返還的全局唯一的ID。
            Mode: 權(quán)限,含義和文件權(quán)限基本一致
            Owner, group: 隊(duì)列建立者的名字和組
            CREATOR, CGROUP:隊(duì)列建立者和組的ID
            NATTCH: 有幾個(gè)進(jìn)程掛接(attach)在這段共享內(nèi)存上
            SEGSZ: 共享內(nèi)存段大小(字節(jié))
            CPID: 產(chǎn)生者PID
            LPID: 最后掛接(attach)或者脫離(detach)者PID
            ATIME: 最后掛接(attach)時(shí)間
            DTIME: 最后脫離(detach)時(shí)間。.
            CTIME: 建立或者最后修改的時(shí)間
            信號(hào)量(semaphore)

            在操作系統(tǒng)中,有些資源數(shù)量是有限的,在同一時(shí)間,只能由有限(一個(gè)或幾個(gè))的進(jìn)程使用和訪(fǎng)問(wèn)。例如磁帶機(jī),同一時(shí)間,只能由一個(gè)進(jìn)程使用。這樣的資源被 稱(chēng)為關(guān)鍵(critical)資源。信號(hào)量就是用來(lái)記錄關(guān)鍵資源的使用情況的。首先,利用系統(tǒng)調(diào)用semget產(chǎn)生一個(gè)信號(hào)量。當(dāng)需要使用關(guān)鍵資源時(shí),調(diào) 用semop,傳遞的參數(shù)為需要使用的資源的數(shù)量,例如2個(gè),參數(shù)就為+2。如果這個(gè)資源有2個(gè)或者更多可用,進(jìn)程就獲得了使用權(quán),否則就必須等待,直到 有足夠的資源可用。當(dāng)進(jìn)程使用資源結(jié)束的時(shí)候,也用semop釋放關(guān)鍵資源。參數(shù)為需要釋放的數(shù)量,例如2,參數(shù)為-2。同message queue一樣,共信號(hào)量一旦產(chǎn)生,除非明確的刪除(某個(gè)有權(quán)限的進(jìn)程或者用ipcrm命令)或者系統(tǒng)重啟。否則,信號(hào)量會(huì)一直保留在系統(tǒng)中。而且,只要 有權(quán)限,就可以對(duì)其進(jìn)行操作。
            ipcs –as命令可以查看Semaphore的狀況:
            Semaphores:
            T      ID        KEY    MODE         OWNER    GROUP  CREATOR   CGROUP NSEMS   OTIME    CTIME
            s       0 0x696e6974 --ra-r--r--      root   system     root   system     8  9:52:53  9:59:30
            T: 類(lèi)型 s 表明這是個(gè)信號(hào)量
            ID: 用戶(hù)自己定義的,在調(diào)用semget時(shí)傳送的參數(shù)。
            Key: 系統(tǒng)返還的全局唯一的ID。
            Mode: 權(quán)限,含義和文件權(quán)限基本一致
            Owner, group: 隊(duì)列建立者的名字和組
            CREATOR, CGROUP:隊(duì)列建立者和組的ID
            NSEMS: 本信號(hào)量上信號(hào)的數(shù)量。
            OTIME: 最后一次操作(semop)的時(shí)間
            CTIM: 建立或者最后修改的時(shí)間


            posted on 2008-10-09 11:20 閱讀(741) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): liunx編程技術(shù)

            香港aa三级久久三级老师2021国产三级精品三级在| 国产一区二区三区久久| 亚洲色欲久久久综合网东京热| 久久久久久久精品妇女99| 久久久久久久久久久| 欧美伊香蕉久久综合类网站| 免费观看久久精彩视频| 久久久久国产精品嫩草影院| 国产综合久久久久| 久久久久久久久66精品片| 精品久久久久久国产91| 久久综合视频网| 精品久久久久中文字| 日产精品久久久久久久性色| 亚洲美日韩Av中文字幕无码久久久妻妇| 精品综合久久久久久97| 久久国产精品免费| 久久国产精品国产自线拍免费| 97视频久久久| 欧美精品丝袜久久久中文字幕 | 久久久久久国产精品美女 | 欧美午夜精品久久久久免费视| 九九精品99久久久香蕉| 狠狠人妻久久久久久综合| 国产婷婷成人久久Av免费高清| 欧美伊人久久大香线蕉综合| 国产精品成人99久久久久 | 久久精品国产亚洲一区二区三区| 久久久国产乱子伦精品作者| 久久AV无码精品人妻糸列| 狠狠色丁香婷婷久久综合 | 国产精品久久久久影院嫩草| 精品久久久久久国产| 18禁黄久久久AAA片| 亚洲а∨天堂久久精品9966| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区| 亚洲国产小视频精品久久久三级 | 久久久久久综合网天天| 国产69精品久久久久久人妻精品| 香蕉久久影院| 久久久久亚洲av综合波多野结衣 |