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

隨筆 - 119  文章 - 290  trackbacks - 0

博客搬家了哦,請(qǐng)移步
叫我abc

常用鏈接

留言簿(12)

隨筆分類

我的博客

搜索

  •  

積分與排名

  • 積分 - 306134
  • 排名 - 84

最新評(píng)論

閱讀排行榜

全文來(lái)源: http://m.shnenglu.com/darkdestiny/

1.服務(wù)器間的異步事務(wù)
上個(gè)月,最有收獲的事情,大概就是這個(gè)了吧。
幾個(gè)不同功能的服務(wù)器相互協(xié)作以實(shí)現(xiàn)一個(gè)角色登錄場(chǎng)景的需求。這是一個(gè)異步的過(guò)程,異步令人討厭的地方就是,他不是一個(gè)服務(wù)器能夠順序完成的事情,而你卻不知道什么時(shí)候什么服務(wù)器會(huì)因?yàn)樘?yáng)風(fēng)的異常活動(dòng)而崩潰。如果你假設(shè)所有服務(wù)器都是穩(wěn)定的,他們最多只有80%的時(shí)間如你所愿,剩下的就是boss的咆哮(2/8原則)。

一開(kāi)始我并不了解異步事務(wù)的概念,所以角色登錄場(chǎng)景的流程寫(xiě)得非常松散。用A,B,C,D合作烤蘋果比方的話,就是
*A抓起一個(gè)蘋果,交給B
*B把蘋果切開(kāi),交給C
*C在蘋果片抹上胡椒,交給D
*D把蘋果烤熟
以人類的眼光看這個(gè)流程,是一個(gè)完美的流水線,而且中途誰(shuí)因?yàn)樘鞜岫舭l(fā)掉的話,大家也都很清楚的知道而作出恰當(dāng)?shù)姆答?暫停流水線,等待信春哥的某人滿血滿buff原地復(fù)活等等)。
但是這樣的流程卻完全不適合映射到程序上——多個(gè)服務(wù)器之間對(duì)彼此行為和狀態(tài)的詳細(xì)跟蹤,是一件多么困難,復(fù)雜,不通用,吃力不討好的事情。那么在程序上,烤蘋果的工人之間就不是在一個(gè)大開(kāi)間暢聊,而是被關(guān)在一個(gè)小黑屋里孤獨(dú)的工作,彼此不能看到,并且傳遞蘋果的空間非常不穩(wěn)定,工人必須時(shí)刻用一只手等蘋果,否則蘋果就會(huì)變成香蕉。工頭Master(M)為節(jié)省成本沒(méi)有開(kāi)空調(diào),所以偶爾有人蒸發(fā)又復(fù)活什么的,但是流水線不會(huì)停下來(lái),100個(gè)蘋果也就烤出80個(gè)左右。

M覺(jué)得虧20個(gè)蘋果沒(méi)什么,但是因?yàn)槌圆簧咸O果而流失的顧客是一個(gè)極大的損失。M決定改進(jìn)流水線,親自參加烤蘋果。
*顧客想吃烤蘋果,M向A索要蘋果
*A抓起一個(gè)蘋果,交給M
*M檢查蘋果,把蘋果交給B
*B把蘋果切開(kāi),交給M
*M把蘋果片交給C
*C在蘋果片抹上胡椒,交給M
*M把蘋果交給D
*D把蘋果烤熟,交給M
此時(shí),M把熱騰騰的烤蘋果交給了顧客,顧客因?yàn)闊狎v騰引起了不好的聯(lián)想,走掉了。
這一次,M對(duì)顧客要吃的每一個(gè)蘋果都貼上一個(gè)唯一標(biāo)簽,設(shè)置一個(gè)5秒超時(shí),如果超時(shí)則重新為顧客烤蘋果,原來(lái)烤了一半的直接扔掉。

前面鋪墊了那么多,其實(shí)就是想說(shuō)明一件事情:處理服務(wù)器間的異步事務(wù),最好設(shè)置一個(gè)master服務(wù)器,集中控制每一個(gè)步驟的運(yùn)作,為每一個(gè)事務(wù)設(shè)置一個(gè)超時(shí);在事務(wù)失敗或者超時(shí)后作出反饋。

2.異步事務(wù)的實(shí)現(xiàn)方式
2.1狀態(tài)機(jī)
第一次我是用狀態(tài)機(jī)實(shí)現(xiàn)的,master等待每個(gè)worker反饋的過(guò)程作為一個(gè)狀態(tài),worker的反饋?zhàn)鳛橐粋€(gè)trigger,迫使master跳轉(zhuǎn)到下個(gè)事務(wù)狀態(tài),執(zhí)行step,接著等待新的反饋,直到事務(wù)結(jié)束。
基于狀態(tài)機(jī)的形式聽(tīng)起來(lái)很直觀,但實(shí)際上用起來(lái)并非如此順手,總是覺(jué)得有些違和,修改的時(shí)候總會(huì)遭遇一些復(fù)雜情景,特別是在中間修改事務(wù)步驟的時(shí)候。
其中我所犯的一個(gè)錯(cuò)誤就是給予每一個(gè)步驟設(shè)置設(shè)置步驟超時(shí)的機(jī)制,這非常不好做,容易出bug,最后才意識(shí)到一個(gè)事務(wù)一個(gè)超時(shí)的規(guī)則。

2.2C協(xié)程
協(xié)程可以認(rèn)為是需要手動(dòng)進(jìn)行調(diào)度的線程,協(xié)程不像線程那樣由OS調(diào)度,協(xié)程何時(shí)運(yùn)行何時(shí)掛起都是由程序員控制的。
C的體系下是沒(méi)有協(xié)程的,雖然找到了一些C協(xié)程的庫(kù),可是接口和實(shí)現(xiàn)都相當(dāng)不雅。唯一一個(gè)我認(rèn)可的,是一個(gè)基于少量多線程來(lái)實(shí)現(xiàn)協(xié)程功能的庫(kù),可是在服務(wù)器上使用多線程是謹(jǐn)慎事項(xiàng)之一。
其他語(yǔ)言體系下的同學(xué),如果有好的協(xié)程支持(最好是基于多堆棧的),大可放心使用。

2.3lua協(xié)程
這是最后實(shí)現(xiàn)并決定的方式,如果今后不改變的話。lua支持多堆棧,所以lua有協(xié)程是理所當(dāng)然的了。
用協(xié)程實(shí)現(xiàn)事務(wù)有哪些好處呢?可以將整個(gè)異步事務(wù)的代碼寫(xiě)在一個(gè)函數(shù)中,就像一個(gè)程序內(nèi)的同步操作一樣,這是一件多么美好而具有可讀性的事情,相比狀態(tài)機(jī)而言。
如何用協(xié)程實(shí)現(xiàn)事務(wù)呢?執(zhí)行一個(gè)事務(wù)時(shí),協(xié)程函數(shù)運(yùn)行,執(zhí)行step,然后在等待反饋的時(shí)候掛起;master收到反饋以后,resume協(xié)程,在上次掛起的地方繼續(xù)往下運(yùn)行,執(zhí)行下一個(gè)step,等待新反饋而掛起;如此反復(fù),直至完成。

posted on 2009-07-05 18:46 LOGOS 閱讀(5153) 評(píng)論(8)  編輯 收藏 引用 所屬分類: month-flow

FeedBack:
# re: 服務(wù)器間異步事務(wù)處理 2009-07-07 22:14 懶人
lua thread用在處理服務(wù)器的對(duì)話框機(jī)制不錯(cuò),等待一個(gè)用戶輸入,開(kāi)啟下一段文字  回復(fù)  更多評(píng)論
  
# re: 服務(wù)器間異步事務(wù)處理 2009-07-08 17:44 developer
博主 能詳細(xì)介紹一下服務(wù)器異步事務(wù)的部分嗎,我剛好也在做相關(guān)的內(nèi)容,希望可以學(xué)習(xí)一下,謝謝了  回復(fù)  更多評(píng)論
  
# re: 服務(wù)器間異步事務(wù)處理 2009-07-08 19:44 LOGOS
@developer
我覺(jué)得我把重點(diǎn)的地方都說(shuō)出來(lái)了。
不知道你指的是什么內(nèi)容
  回復(fù)  更多評(píng)論
  
# re: 服務(wù)器間異步事務(wù)處理 2009-07-09 18:28 developer
是這樣,多服務(wù)器間的異步事務(wù)會(huì)存在并行處理的情況,這時(shí)候可能需要多次分別提交,這樣狀態(tài)就會(huì)比較難控制.

比如,Server A做了一些數(shù)據(jù)庫(kù)操作(沒(méi)有提交),然后更新master的msg 1狀態(tài),等待server B的處理結(jié)果;Server B被觸發(fā)后也執(zhí)行了一些數(shù)據(jù)庫(kù)操作(沒(méi)有提交),然后更新master的msg 1狀態(tài)去告訴Server A自己的執(zhí)行結(jié)果;
那么,問(wèn)題出現(xiàn)了,A和B如何相互確定對(duì)方已經(jīng)成功獲取了狀態(tài)然后提交呢?

場(chǎng)景1: A獲得了B的更新?tīng)顟B(tài),于是繼續(xù)執(zhí)行并提交數(shù)據(jù)庫(kù),然后再更新通知B也提交,但B獲取狀態(tài)失敗并超時(shí)回滾了,A卻無(wú)法回滾數(shù)據(jù)庫(kù)了;
場(chǎng)景2:A獲得了B的更新?tīng)顟B(tài),于是繼續(xù)執(zhí)行,然后再更新通知B提交;B提交后A提交卻失敗了,而B(niǎo)無(wú)法回滾了;

我感覺(jué)這種場(chǎng)景下,不管如何處理,總會(huì)存在一種場(chǎng)景造成整體事務(wù)無(wú)法完全回滾的現(xiàn)象!不知道你是如何處理的?

另外,對(duì)于狀態(tài)控制部分,你使用的什么方式?DB還是消息中間件還是。。。?
  回復(fù)  更多評(píng)論
  
# re: 服務(wù)器間異步事務(wù)處理 2009-07-09 22:37 LOGOS
A或者B的提交操作一旦執(zhí)行,就無(wú)法回滾,是一個(gè)非常讓人為難的情形。我大概會(huì)這么做
場(chǎng)景1:AB合并成一個(gè)服務(wù)器。不過(guò)這可能是現(xiàn)實(shí)情況下最做不到的事情。
場(chǎng)景2:事務(wù)中,把A需要對(duì)數(shù)據(jù)庫(kù)進(jìn)行的操作傳給B,由B完成A和B的操作并提交。這在一些情況下還是可以做到的吧。
場(chǎng)景3:事務(wù)中,A和B都只是修改臨時(shí)表,最后由A或者B將臨時(shí)表的修改寫(xiě)入真表。這也只是針對(duì)某些情況。

”另外,狀態(tài)控制部分,使用什么方式“
這是指什么?是master等待A或者B的某個(gè)操作嗎?  回復(fù)  更多評(píng)論
  
# re: 服務(wù)器間異步事務(wù)處理 2009-07-10 09:57 99讀書(shū)人
不錯(cuò)哦  回復(fù)  更多評(píng)論
  
# re: 服務(wù)器間異步事務(wù)處理 2009-07-10 11:48 developer
因?yàn)槭嵌喾?wù)器的分布式事務(wù),所以必然會(huì)涉及多個(gè)運(yùn)行在不同主機(jī)上的進(jìn)程和多個(gè)DB的數(shù)據(jù)操作,這種情況下,合并服務(wù)器或者不同DB的操作實(shí)際應(yīng)用中都不可行,我覺(jué)得唯一的出路還是通過(guò)服務(wù)器間消息通信來(lái)控制各主機(jī)的行為,但這個(gè)方式的難點(diǎn)就在于,采用何種方式或技巧才能保證消息及時(shí)可靠的傳遞以及如何保證事務(wù)完整性。

目前我使用的是Tuxedo的消息中間件來(lái)在服務(wù)器間傳遞消息,但易用性和可靠性都不理想,以至于必須得考慮任何一次通信中對(duì)方?jīng)]有接收到消息的情況,這實(shí)際又造成任何一方都無(wú)法最終確認(rèn)對(duì)方的執(zhí)行結(jié)果;
你文中說(shuō)的master通過(guò)狀態(tài)機(jī)來(lái)調(diào)度,我覺(jué)得也可以算作是通過(guò)狀態(tài)來(lái)傳遞消息,這個(gè)機(jī)制你具體是如何實(shí)現(xiàn)的呢?

我對(duì)協(xié)程的應(yīng)用不熟悉,感覺(jué)好像是一個(gè)比較優(yōu)雅的解決辦法,但它應(yīng)該是不可以跨服務(wù)器遠(yuǎn)程調(diào)用吧?你是如何應(yīng)用lua的協(xié)程呢?  回復(fù)  更多評(píng)論
  
# re: 服務(wù)器間異步事務(wù)處理 2009-07-10 16:09 LOGOS
通信總是不可靠的,所以發(fā)出一條消息后等待回執(zhí)無(wú)非就3種情況
1.超時(shí)
2.回執(zhí)
3.發(fā)出回執(zhí)的服務(wù)器崩潰
如果能處理到這三種消息,基本上就沒(méi)什么疏漏了。
比較微妙的是回執(zhí)服務(wù)器崩潰的情況,需要去檢查操作是否真的被執(zhí)行了。

事務(wù),被稱為transaction,必須能做到在任何一點(diǎn)上rollback。
在我的想法里,只有master知曉事務(wù)的狀態(tài),并確認(rèn)ABCD的執(zhí)行結(jié)果。ABCD只負(fù)責(zé)do-echo。
狀態(tài)機(jī)和協(xié)程只是用來(lái)在master上維護(hù)事務(wù)狀態(tài)和步驟的一種方案,也許還有別的方案的。

狀態(tài)機(jī)就是設(shè)計(jì)模式里的那個(gè)。
協(xié)程很優(yōu)雅,不可以遠(yuǎn)程調(diào)用。
這兩個(gè)東西,往細(xì)里說(shuō)就大了。  回復(fù)  更多評(píng)論
  
# re: 服務(wù)器間異步事務(wù)處理 2012-05-29 13:40 Midnight
我覺(jué)得樓主光說(shuō)理論沒(méi)用  回復(fù)  更多評(píng)論
  

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              欧美96在线丨欧| 日韩一二三在线视频播| 亚洲高清在线视频| 国产深夜精品| 国产亚洲va综合人人澡精品| 国产欧美日韩在线| 一色屋精品视频在线观看网站| 国产综合久久| 亚洲激情专区| 亚洲一区二区免费在线| 欧美一区二区视频观看视频| 久久人人97超碰国产公开结果| 久久久国产精彩视频美女艺术照福利 | 久久影院午夜论| 久久人人爽人人| 欧美激情国产日韩| 国产精品v欧美精品v日本精品动漫| 国产精品视频99| 黄色亚洲在线| 亚洲精品国产精品国自产观看 | 国产精品一区二区在线观看不卡| 国产精品拍天天在线| 国产日韩综合一区二区性色av| 在线观看日韩av电影| 这里只有精品在线播放| 久久婷婷丁香| 一区二区激情小说| 老色鬼精品视频在线观看播放| 欧美精品一区二区三区在线看午夜| 国产精品国产福利国产秒拍| 国产一区二区三区最好精华液| 亚洲精品欧美| 久久九九热re6这里有精品| 欧美激情黄色片| 国产精品日本一区二区| 欧美揉bbbbb揉bbbbb| 国产精品vvv| 亚洲黄色免费网站| 久久精品国产一区二区三区免费看| 欧美大片一区二区三区| 亚洲永久免费视频| 欧美二区乱c少妇| 国产一区二区欧美| 亚洲午夜精品一区二区| 欧美二区在线播放| 欧美一区二区三区在线视频| 欧美四级电影网站| 亚洲人成网站999久久久综合| 久久国产加勒比精品无码| 一本色道久久| 欧美色视频在线| 夜夜精品视频| 亚洲精品在线一区二区| 欧美大成色www永久网站婷| 国产亚洲综合性久久久影院| 亚洲一区二区三区中文字幕在线| 亚洲欧洲精品天堂一级| 久久蜜桃精品| 在线观看福利一区| 蜜桃av综合| 久久亚洲国产精品一区二区| 国产一区二区在线免费观看| 久久成人羞羞网站| 午夜欧美不卡精品aaaaa| 国产精品户外野外| 亚洲欧美在线x视频| 亚洲视频在线一区| 国产精品一区毛片| 欧美一区午夜精品| 久久成年人视频| 在线免费精品视频| 欧美96在线丨欧| 欧美a级理论片| 亚洲人成欧美中文字幕| 亚洲黄网站黄| 欧美日韩亚洲一区三区| 亚洲自拍偷拍色片视频| 亚洲一区二区三区精品在线| 国产精品久久久久9999吃药| 欧美一区二区观看视频| 欧美一区二区私人影院日本| 精品成人在线视频| 亚洲国产精品va在线看黑人动漫 | 欧美日韩激情小视频| 一区二区三区精品在线| 亚洲一区二三| 国外精品视频| 亚洲国产欧美在线| 欧美午夜一区二区| 久久av在线看| 免费观看日韩| 午夜精品久久久久久久99水蜜桃| 亚洲影院污污.| 怡红院精品视频在线观看极品| 亚洲日韩欧美一区二区在线| 99这里有精品| 亚洲在线观看免费| 亚洲成色精品| 中日韩高清电影网| 在线观看精品| 一个人看的www久久| 激情偷拍久久| 99国产精品久久久| 在线精品亚洲一区二区| 中日韩视频在线观看| 亚洲国产欧美日韩精品| 亚洲天堂男人| 亚洲开发第一视频在线播放| 一区二区三区成人| 亚洲国产精品激情在线观看| 中文精品99久久国产香蕉| 亚洲国产精品精华液2区45| 正在播放日韩| 日韩一本二本av| 久久久久久久成人| 亚洲一区二区三区免费观看| 蜜臀av性久久久久蜜臀aⅴ| 欧美一区二区三区另类 | 国产精品成人在线| 欧美jizz19hd性欧美| 国产精品一级| 一区二区免费在线观看| 亚洲国产中文字幕在线观看| 亚洲欧美日韩一区二区| 亚洲午夜精品一区二区三区他趣| 女女同性精品视频| 久久性天堂网| 国产伦精品一区二区三区高清| 亚洲精品国产精品国自产观看| 狠狠色综合网站久久久久久久| 亚洲自啪免费| 午夜一区不卡| 国产欧美va欧美va香蕉在| 亚洲图片激情小说| 亚洲欧美成人一区二区在线电影| 欧美黄免费看| 亚洲免费观看在线视频| 一区二区高清在线观看| 欧美日韩日日骚| 亚洲精品国产品国语在线app | 欧美在线观看一区二区三区| 国产精品h在线观看| 99爱精品视频| 亚洲一区亚洲二区| 国产精品大片wwwwww| 亚洲午夜在线| 欧美一区二区三区在线播放| 国产精品永久免费视频| 亚洲男人第一网站| 久久狠狠亚洲综合| 激情成人亚洲| 久久综合色影院| 亚洲国产一区二区精品专区| 日韩网站在线观看| 欧美视频在线观看| 亚洲欧美激情视频| 美女精品在线观看| 99国产精品| 国产精品久久久久久影院8一贰佰| 国产伦精品一区二区三区照片91| 久久深夜福利| 国产综合网站| 欧美成人免费网| 一区二区三区国产在线| 久久精品人人做人人爽电影蜜月| 国产最新精品精品你懂的| 久久亚洲色图| 中国成人黄色视屏| 久久综合婷婷| 在线中文字幕日韩| 韩国福利一区| 欧美三级视频在线观看| 欧美一区二区在线免费观看| 亚洲国产欧美一区二区三区丁香婷| 亚洲最新在线| 国产乱理伦片在线观看夜一区| 久久成人人人人精品欧| 欧美成人一区二区三区| 亚洲图片激情小说| 国产一区二区在线观看免费播放 | 99国内精品| 久久看片网站| 亚洲精品乱码久久久久久按摩观| 欧美三级视频在线| 久久久www| 国产精品99久久不卡二区| 男女视频一区二区| 亚洲欧美日韩在线综合| 亚洲黄色在线观看| 国产欧美日韩伦理| 欧美日韩成人一区二区三区| 午夜精品电影| 一区二区三区视频观看| 欧美v亚洲v综合ⅴ国产v| 香蕉免费一区二区三区在线观看 | 亚洲视频在线观看| 亚洲国产精品热久久| 国产区精品视频| 国产精品久在线观看| 欧美激情aaaa|