NetPod和Actor之間的交互

我把

在實(shí)現(xiàn)過程中session被做成了一個SyncDriver咱揍, 可以給actor發(fā)信但是沒有回調(diào)機(jī)制刀崖, 當(dāng)session發(fā)出一個message后它需要調(diào)用Wait()等待actor通知它已經(jīng)收到這個消息(通過actor回發(fā)一個MPK_OK)惊科。由于session工作在ASIO的事件循環(huán)中, 所有的session都被這一個thread來驅(qū)動亮钦, 所以如果每次發(fā)出一個messge到actor都需要進(jìn)行一次等待馆截, 通訊thread的效率必然很差。我們需要communication thread不斷讀取網(wǎng)絡(luò)層消息并轉(zhuǎn)發(fā)給對應(yīng)actor蜂莉,并且不需要等待actor的回復(fù)孙咪。

我目前的想法是在session中注冊一個actor的靜態(tài)成員函數(shù), 既然是static member function那么就可以保證不接觸到actor的內(nèi)部status巡语, 僅僅每次收到一個package header時候這個static memeber function決定繼續(xù)讀取多少字節(jié)的package body翎蹈。zero or non-zero, 等到讀取成功后再一次性打包成一個message發(fā)給對應(yīng)的actor男公。

這個package包含了1. package header荤堪, 2. package body合陵。header是固定的1byte, body是變長buffer澄阳,這個buffer通過全局memory pool進(jìn)行分配拥知。當(dāng)actor收到這個message后(MPK_NET), 處理對應(yīng)的package然后釋放掉package body碎赢。由于申請body buffer在ASIO時間循環(huán)thread中低剔, 釋放body buffer在actor message thread中, 所以需要設(shè)置memory pool為多線程enabled模式肮塞。

這里有個一假設(shè)襟齿, 網(wǎng)絡(luò)層傳入的package的header和body長度不依賴于actor當(dāng)前狀態(tài)。因?yàn)樽缘絪ession中的package header回調(diào)是static的枕赵, 無法獲取actor的狀態(tài)猜欺, 并且actor model也不允許session直接獲取actor的internal status。這個假設(shè)是合理的拷窜。目前的邏輯如下:

1. actor擁有session的pointer开皿, 并且在actor的生命周期內(nèi)session保證valid。

2. 初始化后session先和monoserver交互篮昧, 等成功登陸后monoserver創(chuàng)建player(actor)赋荆, 然后把session指針傳給player, 把player地址傳給session懊昨。

3. session收到header后通過player注冊的static memeber function決定如何接受network data stream并打包成一個package窄潭, 這個過程中如果需要buffer就通過global memory pool申請。

4. session發(fā)送這個package(header疚颊, body pointer)到player狈孔, 然后接受下一個header信认。材义。。

5. player收到這個message嫁赏, 處理其掂, 釋放body pointer回global memory pool。


整個過程中session沒有等待actor回復(fù)潦蝇, actor收到的總是一個完整的package款熬。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市攘乒,隨后出現(xiàn)的幾起案子贤牛,更是在濱河造成了極大的恐慌,老刑警劉巖则酝,帶你破解...
    沈念sama閱讀 216,919評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件殉簸,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)般卑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評論 3 392
  • 文/潘曉璐 我一進(jìn)店門武鲁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蝠检,你說我怎么就攤上這事沐鼠。” “怎么了叹谁?”我有些...
    開封第一講書人閱讀 163,316評論 0 353
  • 文/不壞的土叔 我叫張陵饲梭,是天一觀的道長。 經(jīng)常有香客問我本慕,道長排拷,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,294評論 1 292
  • 正文 為了忘掉前任锅尘,我火速辦了婚禮监氢,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘藤违。我一直安慰自己浪腐,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,318評論 6 390
  • 文/花漫 我一把揭開白布顿乒。 她就那樣靜靜地躺著议街,像睡著了一般。 火紅的嫁衣襯著肌膚如雪璧榄。 梳的紋絲不亂的頭發(fā)上特漩,一...
    開封第一講書人閱讀 51,245評論 1 299
  • 那天,我揣著相機(jī)與錄音骨杂,去河邊找鬼涂身。 笑死,一個胖子當(dāng)著我的面吹牛搓蚪,可吹牛的內(nèi)容都是我干的蛤售。 我是一名探鬼主播,決...
    沈念sama閱讀 40,120評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼妒潭,長吁一口氣:“原來是場噩夢啊……” “哼悴能!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起雳灾,我...
    開封第一講書人閱讀 38,964評論 0 275
  • 序言:老撾萬榮一對情侶失蹤漠酿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后谎亩,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體炒嘲,經(jīng)...
    沈念sama閱讀 45,376評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡谈竿,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,592評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了摸吠。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片空凸。...
    茶點(diǎn)故事閱讀 39,764評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖寸痢,靈堂內(nèi)的尸體忽然破棺而出呀洲,到底是詐尸還是另有隱情,我是刑警寧澤啼止,帶...
    沈念sama閱讀 35,460評論 5 344
  • 正文 年R本政府宣布道逗,位于F島的核電站,受9級特大地震影響献烦,放射性物質(zhì)發(fā)生泄漏滓窍。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,070評論 3 327
  • 文/蒙蒙 一巩那、第九天 我趴在偏房一處隱蔽的房頂上張望吏夯。 院中可真熱鬧,春花似錦即横、人聲如沸噪生。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,697評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽跺嗽。三九已至,卻和暖如春页藻,著一層夾襖步出監(jiān)牢的瞬間桨嫁,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,846評論 1 269
  • 我被黑心中介騙來泰國打工份帐, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留璃吧,地道東北人。 一個月前我還...
    沈念sama閱讀 47,819評論 2 370
  • 正文 我出身青樓弥鹦,卻偏偏與公主長得像肚逸,于是被迫代替她去往敵國和親爷辙。 傳聞我的和親對象是個殘疾皇子彬坏,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,665評論 2 354

推薦閱讀更多精彩內(nèi)容