青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

那誰的技術(shù)博客

感興趣領(lǐng)域:高性能服務(wù)器編程,存儲(chǔ),算法,Linux內(nèi)核
隨筆 - 210, 文章 - 0, 評(píng)論 - 1183, 引用 - 0
數(shù)據(jù)加載中……

讓libevent支持多線程

libevent的使用方式是最開始調(diào)用event_init初始化一個(gè)全局的event_base指針,以后使用其中的API添加新的事件均是對(duì)這個(gè)指針進(jìn)行的操作.

試想如下一種典型的場(chǎng)景:主線程使用libevent處理網(wǎng)絡(luò)IO事件,接收新連接以及接收完客戶端的數(shù)據(jù)之后將該事件交給輔助線程進(jìn)行處理,輔助線程處理完了,需要往客戶端發(fā)送回應(yīng)數(shù)據(jù),則再通過libevent提供的API將這個(gè)事件添加到可讀事件中.但是,由于libevent中這個(gè)event_base指針是全局的,如果多線程同時(shí)添加可能會(huì)造成多線程不安全問題,這個(gè)在libevent的代碼注釋里面作者也做了注解.

在這個(gè)地方有人給出了解決的方案:
已經(jīng)有現(xiàn)成的解決方案:
http://monkeymail.org/archives/libevent-users/2006-October/000257.html

原作者給的地址好像已經(jīng)失效了。iunknownspserver 中就是使用了他的代碼,可以從這里獲得
http://code.google.com/p/spserver/source/browse/trunk/spserver/event_msgqueue.h
(對(duì)應(yīng)的C文件可以通過修改上面文件的后綴名所得).

簡(jiǎn)單的說一說這個(gè)event_msgqueue的原理及使用方式:
它的結(jié)構(gòu)體為:
struct event_msgqueue {
   
int push_fd;
   
int pop_fd;
   
int unlock_between_callbacks;

   
struct event queue_ev;

   sp_thread_mutex_t 
lock;
   
void (*callback)(void *void *);
   
void *cbarg;
   
struct circqueue *queue;
};
其中的queue是保存事件的隊(duì)列,callback是處理事件的回調(diào)函數(shù), lock是線程鎖.

首先,它創(chuàng)建了一對(duì)socketpair(也就是結(jié)構(gòu)體中的push_fd和pop_fd),將其中的一個(gè)通過libevent的event_add接口添加到關(guān)注的事件中,它的事件類型的是READ|PERSIST, 也就是說可讀同時(shí)永不刪除,而這個(gè)事件的回調(diào)函數(shù)是msgqueue_pop,這個(gè)函數(shù)的功能是將當(dāng)前queue中的數(shù)據(jù)一一取出并且調(diào)用callback函數(shù)進(jìn)行回調(diào)處理.
其次,外部的多線程需要往libevent添加事件時(shí)使用這個(gè)文件提供的msgqueue_push函數(shù)進(jìn)行添加,此時(shí), 往socketpair中發(fā)送一個(gè)字節(jié)的數(shù)據(jù), 這么做的目的是為了讓第一步已經(jīng)添加的socketpair得到響應(yīng),此時(shí), 由第一步,必然會(huì)觸發(fā)之前注冊(cè)的回調(diào)函數(shù)msgqueue_pop,將這個(gè)隊(duì)列中的事件取出來進(jìn)行處理.

這里使用socketpair起到了一個(gè)通知的作用,當(dāng)隊(duì)列中有數(shù)據(jù)時(shí),通過向socketpair發(fā)送數(shù)據(jù)以調(diào)用msgqueue_pop,將數(shù)據(jù)取出來進(jìn)行處理.
可見,這個(gè)event_msgqueue起了一個(gè)中間層的作用,輔助線程要往libevent添加事件就通過這個(gè)隊(duì)列,當(dāng)隊(duì)列中有數(shù)據(jù)時(shí)再觸發(fā)libevent的事件處理機(jī)制進(jìn)行處理.設(shè)計(jì)的非常巧妙.

感謝iunknown兄的指點(diǎn):)


posted on 2009-01-12 14:49 那誰 閱讀(23646) 評(píng)論(6)  編輯 收藏 引用 所屬分類: 網(wǎng)絡(luò)編程服務(wù)器設(shè)計(jì)libevent

評(píng)論

# re: 讓libevent支持多線程  回復(fù)  更多評(píng)論   

呵呵,你看一下libevent中對(duì)信號(hào)的處理,和這種方式是一模一樣的。Again,這也是很多事件處理框架所采用的方式(pipe或socketpair),即把多種事件源最后都統(tǒng)一到一種事件上去了——在Linux下,通常就是epoll處理的文件事件(socket也是文件)。
2009-01-19 14:46 | Joshua Zhu

# re: 讓libevent支持多線程  回復(fù)  更多評(píng)論   

你 能給出 event_msgqueue的一個(gè)完整例子嗎?我的email:dragzhb@yahoo.com.cn,能發(fā)到我的郵箱嗎?多謝!
2010-01-21 15:17 | hbzhang

# re: 讓libevent支持多線程  回復(fù)  更多評(píng)論   

1樓說的對(duì)啊,這個(gè)就是libevent對(duì)signal的處理方式。
libevent就是講io事件、定時(shí)器和信號(hào)等事件統(tǒng)一到另外一件事去了。
這里用的到的也是這個(gè)思想。
2011-04-22 15:52 | zhanglistar

# re: 讓libevent支持多線程  回復(fù)  更多評(píng)論   

我需要完整的代碼啊 初學(xué)者 光看這些 還真不懂~~
2013-03-13 17:54 | Metre

# re: 讓libevent支持多線程  回復(fù)  更多評(píng)論   

您好http://code.google.com/p/spserver/source/browse/trunk/spserver/event_msgqueue.h 好像失效了能否發(fā)我郵箱729720390@qq.com 謝謝!
2015-03-06 11:53 | ruanquanfu

# re: 讓libevent支持多線程  回復(fù)  更多評(píng)論   

剛開始以為有個(gè)新的方法可以實(shí)現(xiàn)多線程。。。。其實(shí)就試類似pipe的方式, memcache就是這樣做的,可以參考一下
2015-05-11 23:12 | fly2010love
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲一区日韩| 久久综合网hezyo| 国产亚洲精品久久久久动| 欧美激情精品久久久| 欧美韩国日本一区| 欧美精品久久久久a| 欧美精品福利在线| 国产精品高潮呻吟视频| 国产欧美日韩一级| 精品不卡一区| 日韩视频免费大全中文字幕| 这里只有精品视频| 欧美一区二视频| 另类综合日韩欧美亚洲| 亚洲国产一区二区三区青草影视| 亚洲二区免费| 亚洲综合成人婷婷小说| 久久夜色精品国产欧美乱| 欧美精品尤物在线| 国产精品网红福利| 亚洲黄色精品| 欧美一区二区国产| 亚洲国产精品尤物yw在线观看| 一区二区国产日产| 久久永久免费| 国产伦精品一区二区三区高清| 亚洲国产成人久久综合一区| 亚洲欧美日韩一区二区| 欧美福利小视频| 亚洲欧美大片| 在线综合亚洲| 久久久久久九九九九| 91久久精品一区| 免费不卡亚洲欧美| 国产精品日韩| 亚洲精品综合精品自拍| 欧美一区二区三区免费观看视频| 欧美不卡视频一区发布| 亚洲一本大道在线| 欧美激情一二区| 国产一区三区三区| 性伦欧美刺激片在线观看| 亚洲国产一区二区三区青草影视 | 国产欧美午夜| 亚洲视频电影在线| 亚洲国产精品成人| 久久亚洲精选| 好吊色欧美一区二区三区四区| 亚洲欧美国产日韩天堂区| 欧美激情亚洲激情| 久久先锋影音| 黄色国产精品一区二区三区| 午夜精品久久久久久久久久久| 亚洲精品国产拍免费91在线| 你懂的亚洲视频| 亚洲高清不卡在线观看| 久久久五月婷婷| 久久精品一区蜜桃臀影院| 国内精品免费在线观看| 久久久五月婷婷| 久久久久久一区| 黄色精品一区二区| 免费美女久久99| 欧美1区2区| 日韩视频永久免费观看| 亚洲激情成人网| 欧美激情性爽国产精品17p| 亚洲理论在线| 亚洲美女淫视频| 国产精品地址| 久久精品视频在线看| 欧美在线免费| 在线不卡中文字幕播放| 免费成人av| 欧美精品亚洲精品| 亚洲欧美日韩一区二区三区在线观看| 亚洲深夜福利视频| 国产在线高清精品| 欧美sm视频| 欧美午夜片在线免费观看| 亚洲欧美制服另类日韩| 欧美一区永久视频免费观看| 激情懂色av一区av二区av| 亚洲国产精品久久精品怡红院| 欧美区一区二区三区| 性欧美暴力猛交69hd| 久久九九国产精品| 欧美午夜在线视频| 欧美激情第10页| 欧美日产在线观看| 亚洲一区中文| 久久aⅴ乱码一区二区三区| 亚洲二区视频在线| 一区二区三区黄色| 黄色工厂这里只有精品| 99精品国产高清一区二区| 国产亚洲欧美aaaa| 亚洲黄色大片| 国产日韩一区二区三区在线| 欧美激情综合色| 国产精品永久免费观看| 欧美成人伊人久久综合网| 欧美色偷偷大香| 免费日韩成人| 国产精品久久久91| 亚洲电影毛片| 国产尤物精品| 亚洲伊人久久综合| 亚洲美女黄色| 久久精品国产一区二区三区免费看 | 久久精品一区二区三区不卡| 一本色道久久综合狠狠躁篇的优点 | 亚洲欧美在线一区| 亚洲理论在线| 久久精品在线免费观看| 亚洲欧美怡红院| 欧美精品免费在线观看| 免费永久网站黄欧美| 国产色视频一区| 亚洲免费一在线| 亚洲婷婷在线| 欧美精品在线一区二区三区| 免费日本视频一区| 精品av久久久久电影| 亚洲一区二区三区午夜| 一区二区三区精品久久久| 蜜臀av一级做a爰片久久| 老司机免费视频一区二区三区| 国产精品久久久久影院亚瑟| 亚洲乱码国产乱码精品精天堂| 亚洲区一区二区三区| 麻豆国产va免费精品高清在线| 久久精品成人欧美大片古装| 国产精品一级久久久| 一区二区三区国产精品| 亚洲影院色无极综合| 欧美系列亚洲系列| 亚洲视频在线观看网站| 亚洲制服av| 国产精品三级久久久久久电影| 中文av一区二区| 欧美一区二区性| 国产亚洲福利| 欧美在线一区二区| 狂野欧美激情性xxxx| 狠狠色综合网| 欧美日韩国产精品一区| 久久露脸国产精品| 国产美女精品人人做人人爽| 亚洲视频大全| 欧美专区在线观看| 狠狠做深爱婷婷久久综合一区 | 亚洲男人第一网站| 国产精品三级视频| 久久精品首页| 亚洲精品国精品久久99热| 亚洲一区精彩视频| 国产欧美日韩亚洲一区二区三区| 久久国产主播| 最近看过的日韩成人| 亚洲欧美国产制服动漫| 国产一区二区三区精品久久久| 久久精品国产亚洲一区二区三区| 欧美1区3d| 亚洲欧美电影院| 影院欧美亚洲| 国产精品久久久久久久9999| 欧美影院精品一区| 亚洲精品乱码久久久久久| 亚洲一区视频在线| 好男人免费精品视频| 欧美绝品在线观看成人午夜影视 | 欧美精品在欧美一区二区少妇| 一本一本久久a久久精品综合麻豆| 欧美亚洲一区二区在线| 激情视频亚洲| 欧美日韩在线播放一区二区| 欧美一区激情视频在线观看| 亚洲国产日日夜夜| 欧美一级片久久久久久久| 亚洲国产精品电影在线观看| 国产精品麻豆成人av电影艾秋| 久久艳片www.17c.com| 这里只有视频精品| 欧美暴力喷水在线| 翔田千里一区二区| 亚洲国产影院| 国内久久婷婷综合| 国产精品九九| 欧美猛交免费看| 看欧美日韩国产| 性色一区二区三区| 一区二区久久久久| 亚洲激情网站免费观看| 久久人人爽国产| 午夜精品理论片| 99re国产精品| 亚洲精品在线电影| 亚洲黄色一区二区三区| 在线看片成人|