婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > linux使用共享內存通信的進程同步退出問題

linux使用共享內存通信的進程同步退出問題

熱門標簽:電話機器人哪里有賣的 新鄭電銷外呼系統線路 河北語音電銷機器人 壽光百度地圖標注中心網站 商戶地圖標注 怎樣給景區加百度地圖標注 樺甸電銷機器人 河南智能電話機器人公司 地球地圖標注方法

兩個甚至多個進程使用共享內存(shm)通信,總遇到同步問題。這里的“同步問題”不是說進程讀寫同步問題,這個用信號量就好了。這里的同步問題說的是同步退出問題,到底誰先退出,怎么知道對方退出了。舉個例子:進程負責讀寫數據庫A,進程B負責處理數據。那么進程A得比進程B晚退出才行,因為要保存進程B處理完的數據。可是A不知道B什么時候退出啊。A、B是無關聯的進程,也不知道對方的pid。它們唯一的關聯就是讀寫同一塊共享內存。正常情況下,進程B在共享內存中寫個標識:進程A你可以退出了,也是可以的。不過進程B可能是異常退出,連標識都來不及寫。其次,共享內存用來做數據通信的,加這么個標識感覺不太好,有濫用的感覺。

  采用socket通信沒有這個問題,因為進程B退出怎么也會導致socket斷開,哪怕是超時。但shm卻沒有協議來檢測這些行為,如果自己也做一個未免太麻煩。那就從共享內存下手吧。

  共享內存是由內核來管理的,一個進程刪除本身打開的共享內存并不影響另一個進程的共享內存,哪怕都是同一塊共享內存。這是因為共享內存在內核中一個引用計數,一個進程使用該共享內存就會導致引用計數加1。如果其中一個進程調用了刪除函數,只有這個計數為0才會真正刪除共享內存。那么,需要最后才退出的進程檢測這個計數就可以了。

  在System V的共享內存中,創建一個共享內存會初始化一個結構:


復制代碼
代碼如下:

struct shmid_ds {
struct ipc_perm shm_perm; /* Ownership and permissions */
size_t shm_segsz; /* Size of segment (bytes) */
time_t shm_atime; /* Last attach time */
time_t shm_dtime; /* Last detach time */
time_t shm_ctime; /* Last change time */
pid_t shm_cpid; /* PID of creator */
pid_t shm_lpid; /* PID of last shmat(2)/shmdt(2) */
shmatt_t shm_nattch; /* No. of current attaches */
...
};

使用shmctl函數可以讀取該結構體,其中的shm_nattch就是使用該共享內存的進程數。

  不過,現在有了新的POSIX標準,當然要用新標準了。shm_open創建的共享內存也具有“一個進程刪除本身打開的共享內存并不影響另一個進程的共享內存”的特點。可是用shm_open創建的共享內存不再有上面的結構,那么,內核是怎么管理shm_open創建共享內存??看下面的源碼:


復制代碼
代碼如下:

/* shm_open - open a shared memory file *//p> p>/* Copyright 2002, Red Hat Inc. *//p> p>#include sys/types.h>
#include sys/mman.h>
#include unistd.h>
#include string.h>
#include fcntl.h>
#include limits.h>/p> p>int
shm_open (const char *name, int oflag, mode_t mode)
{
int fd;
char shm_name[PATH_MAX+20] = "/dev/shm/";/p> p> /* skip opening slash */
if (*name == '/')
++name;/p> p> /* create special shared memory file name and leave enough space to
cause a path/name error if name is too long */
strlcpy (shm_name + 9, name, PATH_MAX + 10);/p> p> fd = open (shm_name, oflag, mode);/p> p> if (fd != -1)
{
/* once open we must add FD_CLOEXEC flag to file descriptor */
int flags = fcntl (fd, F_GETFD, 0);/p> p> if (flags >= 0)
{
flags |= FD_CLOEXEC;
flags = fcntl (fd, F_SETFD, flags);
}/p> p> /* on failure, just close file and give up */
if (flags == -1)
{
close (fd);
fd = -1;
}
}/p> p> return fd;
}

我嚓,這就是創建一個普通的文件啊,只是創建的位置在/dev/shm下(也就是RAM上)。再來看看刪除共享內存的函數shm_unlink:


復制代碼
代碼如下:

/* shm_unlink - remove a shared memory file *//p> p>/* Copyright 2002, Red Hat Inc. *//p> p>#include sys/types.h>
#include sys/mman.h>
#include unistd.h>
#include string.h>
#include limits.h>/p> p>int
shm_unlink (const char *name)
{
int rc;
char shm_name[PATH_MAX+20] = "/dev/shm/";/p> p> /* skip opening slash */
if (*name == '/')
++name;/p> p> /* create special shared memory file name and leave enough space to
cause a path/name error if name is too long */
strlcpy (shm_name + 9, name, PATH_MAX + 10);/p> p> rc = unlink (shm_name);/p> p> return rc;
}

這也只是一個普通的unlink函數。也就是說,POSIX標準的共享內存就是一個文件。所謂的“一個進程刪除本身打開的共享內存并不影響另一個進程的共享內存”就相當于你用fstream對象打開了一個文件,然后去文件夾把文件刪除了(也就是對文件進行了unlink操作),可是fstream對象還可以正常讀寫文件,并沒有什么引用計數。這下好了,進程退出時又沒法同步了。

  不過,在linux下怎么會有解決不了的問題呢?解決不了只能說明自己太菜。既然是文件,那就從文件下手。那文件有什么是原子操作,又可以計數的呢。答案:硬鏈接。比如:


復制代碼
代碼如下:

xzc@xzc-HP-ProBook-4446s:/dev/shm$ stat abc
文件:"abc"
大小:4 塊:8 IO 塊:4096 普通文件
設備:15h/21d Inode:5743159 硬鏈接:1
權限:(0664/-rw-rw-r--) Uid:( 1000/ xzc) Gid:( 1000/ xzc)
最近訪問:2015-01-25 21:27:00.961053098 +0800
最近更改:2015-01-25 21:27:00.961053098 +0800
最近改動:2015-01-25 21:27:00.961053098 +0800
創建時間:-
xzc@xzc-HP-ProBook-4446s:/dev/shm$

這個硬鏈接可以通過fstat函數獲取。可是要這樣實現的話,意味著需要先創建一塊共享內存,每個進程引用的時候需要調用link函數來創建一個硬鏈接。問題解決了,可是這樣會在/dev/shm下多個N多個文件。這可是RAM啊,雖然現在的服務器都比較牛,但這樣做也不太好吧。好吧,還有一個flock文件鎖。flock使用LOCK_SH參數多個進程對同一個文件加鎖。這樣,進程B初始化共享內存時加鎖(可以有多個這樣的進程),在退出(包括異常退出)時解鎖。進程A在退出時檢測這個鎖。當發現無鎖時說明可以安全退出了。

  同步退出的問題基本解決了。來不及寫代碼去驗證,下次吧。

PS:內核unlink時應該也是有計數才知道當前有沒有進程打開文件,在什么時候應該刪除文件。這個還得去查資料,看用不用得上。另外lsof這個工具是可以檢測到所有打開該共享內存的進程及相應的狀態。這個應該也是有對應的api的,只是現在還沒搞懂。

標簽:阜陽 來賓 迪慶 忻州 遼陽 荊州 楚雄 淄博

巨人網絡通訊聲明:本文標題《linux使用共享內存通信的進程同步退出問題》,本文關鍵詞  linux,使用,共享,內存,通信,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《linux使用共享內存通信的進程同步退出問題》相關的同類信息!
  • 本頁收集關于linux使用共享內存通信的進程同步退出問題的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美午夜电影在线播放| 欧美激情一区二区三区四区| 91久久精品一区二区| 欧美日韩国产精品自在自线| 精品国产乱子伦一区| 99久久精品一区二区| 欧美午夜电影网| 国产精品女同一区二区三区| 视频一区中文字幕| 欧洲视频一区二区| 欧美日韩在线一区二区| 欧美国产日韩亚洲一区| 天堂久久一区二区三区| 一本久久精品一区二区| 国产精品女上位| 国产黄人亚洲片| 久久综合狠狠综合久久激情| 蜜臀精品一区二区三区在线观看| 91视频一区二区| 日韩美女视频一区二区在线观看| 国产精品久久久久久久岛一牛影视| 日韩成人一区二区三区在线观看| 色综合天天综合给合国产| 日本一区二区三区在线不卡| 捆绑调教一区二区三区| 欧美日韩精品一区二区| 亚洲精品国产精华液| 91丨porny丨蝌蚪视频| 国产精品久久久久久久久久久免费看| 国产自产2019最新不卡| 精品国产一二三区| 秋霞电影一区二区| 精品国产乱码久久久久久图片 | 国产精品久久久久久久久图文区 | 欧美日韩国产成人在线91| 亚洲啪啪综合av一区二区三区| 国产盗摄视频一区二区三区| 精品福利一区二区三区 | 日韩午夜在线影院| 日本不卡在线视频| 日韩精品综合一本久道在线视频| 亚洲成人在线免费| 欧美最新大片在线看| 午夜精品福利视频网站| 7777女厕盗摄久久久| 久久99国产精品久久| 久久综合色婷婷| 国产黄色精品网站| 亚洲精品视频免费观看| 欧美日韩成人在线| 一区二区高清免费观看影视大全 | 国产日韩欧美a| 国产成人8x视频一区二区| 国产精品高清亚洲| 91香蕉视频mp4| 日本美女一区二区三区视频| 久久综合九色综合97婷婷| 99在线精品观看| 天堂va蜜桃一区二区三区| www国产精品av| 波多野洁衣一区| 五月婷婷激情综合| 久久久国产一区二区三区四区小说| 岛国精品在线观看| 亚洲福利视频导航| 亚洲欧洲综合另类在线| 18成人在线视频| 国产精品久久久久久久久免费相片 | 蜜臀va亚洲va欧美va天堂| 亚洲国产精品嫩草影院| 亚洲国产日韩a在线播放性色| √…a在线天堂一区| 中文字幕五月欧美| 亚洲欧美另类久久久精品2019| 久久久国产精品不卡| 国产片一区二区| 中文字幕字幕中文在线中不卡视频| 国产精品久久久久婷婷| 国产精品不卡在线| 亚洲欧美另类久久久精品2019| 日韩福利电影在线| 久久国产精品第一页| 国产成人精品一区二| 99久久99久久精品国产片果冻| 99精品视频一区二区三区| 色狠狠综合天天综合综合| 精品视频免费看| 久久一区二区三区国产精品| 亚洲国产成人午夜在线一区| 亚洲日本va在线观看| 婷婷久久综合九色综合绿巨人 | 亚洲乱码国产乱码精品精小说| 亚洲欧美日本韩国| 欧美aaaaaa午夜精品| 丁香另类激情小说| 欧美日韩的一区二区| 欧美韩日一区二区三区| 一区二区三区**美女毛片| 麻豆一区二区三区| av在线这里只有精品| 欧美日韩成人综合天天影院| 久久精品亚洲乱码伦伦中文| 亚洲精品ww久久久久久p站| 奇米一区二区三区| 99国产精品国产精品毛片| 欧美一区二区免费观在线| 一区免费观看视频| 日本v片在线高清不卡在线观看| 懂色av一区二区三区免费看| 91福利国产成人精品照片| 精品国精品国产| 一区二区不卡在线播放 | 国产一区二区三区久久悠悠色av| 大白屁股一区二区视频| 在线播放一区二区三区| 亚洲视频中文字幕| 国产久卡久卡久卡久卡视频精品| 91精品91久久久中77777| 久久久国产一区二区三区四区小说| 一区二区三区中文字幕精品精品| 久久国产精品区| 欧美蜜桃一区二区三区| 亚洲人午夜精品天堂一二香蕉| 美女诱惑一区二区| 99国产精品国产精品久久| 日韩欧美另类在线| 偷拍日韩校园综合在线| 欧日韩精品视频| 国产精品理论片| 国产成人精品网址| 久久色中文字幕| 久久99精品久久久久婷婷| 欧美日韩一区二区三区视频| 亚洲精品久久久久久国产精华液| 国产成a人亚洲| 26uuu亚洲| 精品无人区卡一卡二卡三乱码免费卡| 在线免费一区三区| 亚洲一二三四在线观看| 91麻豆免费看| 亚洲蜜臀av乱码久久精品 | 欧美成人三级在线| 亚洲777理论| 欧美猛男超大videosgay| 亚洲一区二区在线免费观看视频| 色噜噜狠狠成人中文综合| 成人免费小视频| 色94色欧美sute亚洲线路一久 | 亚洲精品中文在线影院| 91视频xxxx| 亚洲女厕所小便bbb| 在线亚洲+欧美+日本专区| 亚洲男人的天堂av| 欧美日韩亚洲另类| 日韩黄色免费电影| 精品少妇一区二区三区视频免付费 | 欧美一卡二卡在线观看| 日韩国产在线观看一区| 欧美日韩一级黄| 热久久国产精品| 久久久国产精品午夜一区ai换脸| 国产另类ts人妖一区二区| 国产精品久久三区| 欧美艳星brazzers| 久久66热偷产精品| 国产精品久久久久久久久晋中 | 丝袜美腿亚洲一区二区图片| 91麻豆精品国产91| 国产麻豆成人传媒免费观看| 亚洲欧美一区二区在线观看| 欧美三级电影一区| 国产一区二区剧情av在线| 亚洲美女屁股眼交| 欧美xxx久久| 91麻豆产精品久久久久久| 日韩不卡一二三区| 中文字幕日韩一区| 91麻豆精品国产91久久久| 成人h精品动漫一区二区三区| 图片区小说区国产精品视频| 国产精品区一区二区三区| 欧美日韩国产首页| 国产黄人亚洲片| 亚洲chinese男男1069| 国产欧美日韩在线看| 91.xcao| 91在线精品秘密一区二区| 秋霞电影一区二区| 亚洲欧美二区三区| 精品福利一区二区三区 | 99国产精品视频免费观看| 青青草原综合久久大伊人精品优势| 国产精品人人做人人爽人人添| 欧美日韩精品专区| 色综合久久久久久久| 在线亚洲精品福利网址导航| 极品少妇xxxx精品少妇偷拍 | 午夜精品久久久久影视| 国产精品网曝门| 久久精品一区二区|