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

隨筆 - 119  文章 - 290  trackbacks - 0

博客搬家了哦,請移步
叫我abc

常用鏈接

留言簿(12)

隨筆分類

我的博客

搜索

  •  

積分與排名

  • 積分 - 306391
  • 排名 - 84

最新評論

閱讀排行榜

全文來源: http://m.shnenglu.com/darkdestiny/

1.服務器間的異步事務
上個月,最有收獲的事情,大概就是這個了吧。
幾個不同功能的服務器相互協作以實現一個角色登錄場景的需求。這是一個異步的過程,異步令人討厭的地方就是,他不是一個服務器能夠順序完成的事情,而你卻不知道什么時候什么服務器會因為太陽風的異常活動而崩潰。如果你假設所有服務器都是穩定的,他們最多只有80%的時間如你所愿,剩下的就是boss的咆哮(2/8原則)。

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

M覺得虧20個蘋果沒什么,但是因為吃不上蘋果而流失的顧客是一個極大的損失。M決定改進流水線,親自參加烤蘋果。
*顧客想吃烤蘋果,M向A索要蘋果
*A抓起一個蘋果,交給M
*M檢查蘋果,把蘋果交給B
*B把蘋果切開,交給M
*M把蘋果片交給C
*C在蘋果片抹上胡椒,交給M
*M把蘋果交給D
*D把蘋果烤熟,交給M
此時,M把熱騰騰的烤蘋果交給了顧客,顧客因為熱騰騰引起了不好的聯想,走掉了。
這一次,M對顧客要吃的每一個蘋果都貼上一個唯一標簽,設置一個5秒超時,如果超時則重新為顧客烤蘋果,原來烤了一半的直接扔掉。

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

2.異步事務的實現方式
2.1狀態機
第一次我是用狀態機實現的,master等待每個worker反饋的過程作為一個狀態,worker的反饋作為一個trigger,迫使master跳轉到下個事務狀態,執行step,接著等待新的反饋,直到事務結束。
基于狀態機的形式聽起來很直觀,但實際上用起來并非如此順手,總是覺得有些違和,修改的時候總會遭遇一些復雜情景,特別是在中間修改事務步驟的時候。
其中我所犯的一個錯誤就是給予每一個步驟設置設置步驟超時的機制,這非常不好做,容易出bug,最后才意識到一個事務一個超時的規則。

2.2C協程
協程可以認為是需要手動進行調度的線程,協程不像線程那樣由OS調度,協程何時運行何時掛起都是由程序員控制的。
C的體系下是沒有協程的,雖然找到了一些C協程的庫,可是接口和實現都相當不雅。唯一一個我認可的,是一個基于少量多線程來實現協程功能的庫,可是在服務器上使用多線程是謹慎事項之一。
其他語言體系下的同學,如果有好的協程支持(最好是基于多堆棧的),大可放心使用。

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

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

FeedBack:
# re: 服務器間異步事務處理 2009-07-07 22:14 懶人
lua thread用在處理服務器的對話框機制不錯,等待一個用戶輸入,開啟下一段文字  回復  更多評論
  
# re: 服務器間異步事務處理 2009-07-08 17:44 developer
博主 能詳細介紹一下服務器異步事務的部分嗎,我剛好也在做相關的內容,希望可以學習一下,謝謝了  回復  更多評論
  
# re: 服務器間異步事務處理 2009-07-08 19:44 LOGOS
@developer
我覺得我把重點的地方都說出來了。
不知道你指的是什么內容
  回復  更多評論
  
# re: 服務器間異步事務處理 2009-07-09 18:28 developer
是這樣,多服務器間的異步事務會存在并行處理的情況,這時候可能需要多次分別提交,這樣狀態就會比較難控制.

比如,Server A做了一些數據庫操作(沒有提交),然后更新master的msg 1狀態,等待server B的處理結果;Server B被觸發后也執行了一些數據庫操作(沒有提交),然后更新master的msg 1狀態去告訴Server A自己的執行結果;
那么,問題出現了,A和B如何相互確定對方已經成功獲取了狀態然后提交呢?

場景1: A獲得了B的更新狀態,于是繼續執行并提交數據庫,然后再更新通知B也提交,但B獲取狀態失敗并超時回滾了,A卻無法回滾數據庫了;
場景2:A獲得了B的更新狀態,于是繼續執行,然后再更新通知B提交;B提交后A提交卻失敗了,而B無法回滾了;

我感覺這種場景下,不管如何處理,總會存在一種場景造成整體事務無法完全回滾的現象!不知道你是如何處理的?

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

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

目前我使用的是Tuxedo的消息中間件來在服務器間傳遞消息,但易用性和可靠性都不理想,以至于必須得考慮任何一次通信中對方沒有接收到消息的情況,這實際又造成任何一方都無法最終確認對方的執行結果;
你文中說的master通過狀態機來調度,我覺得也可以算作是通過狀態來傳遞消息,這個機制你具體是如何實現的呢?

我對協程的應用不熟悉,感覺好像是一個比較優雅的解決辦法,但它應該是不可以跨服務器遠程調用吧?你是如何應用lua的協程呢?  回復  更多評論
  
# re: 服務器間異步事務處理 2009-07-10 16:09 LOGOS
通信總是不可靠的,所以發出一條消息后等待回執無非就3種情況
1.超時
2.回執
3.發出回執的服務器崩潰
如果能處理到這三種消息,基本上就沒什么疏漏了。
比較微妙的是回執服務器崩潰的情況,需要去檢查操作是否真的被執行了。

事務,被稱為transaction,必須能做到在任何一點上rollback。
在我的想法里,只有master知曉事務的狀態,并確認ABCD的執行結果。ABCD只負責do-echo。
狀態機和協程只是用來在master上維護事務狀態和步驟的一種方案,也許還有別的方案的。

狀態機就是設計模式里的那個。
協程很優雅,不可以遠程調用。
這兩個東西,往細里說就大了。  回復  更多評論
  
# re: 服務器間異步事務處理 2012-05-29 13:40 Midnight
我覺得樓主光說理論沒用  回復  更多評論
  

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   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>
              欧美视频一区二| 一本久道久久综合婷婷鲸鱼| 亚洲欧美日韩在线| 99视频有精品| 亚洲综合成人在线| 欧美一级网站| 麻豆成人小视频| 欧美成va人片在线观看| 欧美激情麻豆| 欧美香蕉视频| 国产精品扒开腿做爽爽爽视频| 最新亚洲电影| 国产精品永久免费观看| 国产精品夜夜嗨| 国产精品视频精品视频| 国产精品国产三级国产专区53 | 国产一区二区三区不卡在线观看| 国产精品一区二区久久久久| 国产香蕉97碰碰久久人人| 一区二区三区在线观看欧美| 亚洲精品乱码久久久久久蜜桃麻豆| 亚洲色在线视频| 久久久伊人欧美| 亚洲人成网站精品片在线观看| 久久亚洲精品视频| 亚洲第一搞黄网站| 亚洲深夜影院| 亚洲第一主播视频| 亚洲日韩视频| 9色精品在线| 欧美亚洲免费电影| 欧美国产先锋| 国产亚洲美州欧州综合国| 亚洲国产高清视频| 翔田千里一区二区| 亚洲日本中文| 久久精品人人| 欧美精品三级日韩久久| 国产精品一区二区久久久| 亚洲免费av片| 亚洲欧美日韩视频二区| 亚洲国产女人aaa毛片在线| 亚洲——在线| 亚洲欧美亚洲| 久热这里只精品99re8久| 欧美成人综合在线| 亚洲一区二区精品视频| 欧美电影免费| 狠狠狠色丁香婷婷综合激情| 午夜精品一区二区三区电影天堂| 欧美激情中文字幕一区二区| 久久精品国产清自在天天线| 国产精品视频导航| 亚洲图片欧美一区| 亚洲图片欧洲图片日韩av| 男女av一区三区二区色多| 亚洲一区二区三区乱码aⅴ蜜桃女 亚洲一区二区三区乱码aⅴ | 蜜桃av一区二区| 一本色道久久88精品综合| 久久日韩精品| 亚洲免费影院| 亚洲国产成人午夜在线一区| 亚洲一区二区视频| 欧美高清视频一区| 尤物九九久久国产精品的分类| 亚洲自拍偷拍一区| 日韩视频永久免费观看| 欧美黄色精品| 亚洲激情社区| 久久久精品日韩欧美| 亚洲高清不卡av| 久久资源av| 亚洲精品久久久久久下一站 | 国产日韩欧美亚洲| 亚洲一区日本| 亚洲免费观看视频| 欧美另类69精品久久久久9999| 最新国产乱人伦偷精品免费网站| 欧美国产日韩一区| 欧美成人午夜影院| 亚洲黄页一区| 亚洲三级网站| 欧美激情一区在线观看| 日韩一级黄色大片| 在线一区二区三区做爰视频网站| 欧美日一区二区三区在线观看国产免| 一本色道久久综合亚洲91| 亚洲高清在线观看一区| 欧美国产日韩亚洲一区| 一本一本a久久| 亚洲天堂免费观看| 国产伦精品免费视频| 欧美亚洲综合另类| 男男成人高潮片免费网站| 中日韩男男gay无套| 午夜亚洲激情| 亚洲欧洲一二三| 亚洲国产二区| 亚洲男同1069视频| 在线观看一区二区精品视频| 美女久久一区| 欧美日韩综合| 久久综合网络一区二区| 欧美日韩免费在线观看| 久久夜色精品国产亚洲aⅴ| 欧美大片在线观看一区| 亚洲一区二区精品在线观看| 午夜国产精品视频免费体验区| 国产欧美一区二区精品性色| 久久免费视频在线| 亚洲精品少妇30p| 亚洲精品专区| 国产日韩欧美综合| 久久蜜桃资源一区二区老牛| 欧美一级久久久| 欧美日韩午夜剧场| 美女被久久久| 欧美精品一区二区三区高清aⅴ| 欧美日韩亚洲一区二区三区在线 | 亚洲欧美国产制服动漫| 激情一区二区三区| 在线综合视频| 亚洲裸体在线观看| 久久在线免费观看视频| 欧美在线视频在线播放完整版免费观看| 久久精品99国产精品日本| 午夜亚洲福利| 国产精品福利久久久| 一本色道久久综合亚洲精品不| 免播放器亚洲一区| 国产女同一区二区| 一本到12不卡视频在线dvd| 伊人狠狠色j香婷婷综合| 亚洲一区二区三区四区五区午夜| 亚洲欧洲日本国产| 免费在线看成人av| 狼人天天伊人久久| 国产一区日韩欧美| 亚洲影音一区| 亚洲欧美日韩区 | 久久在线观看视频| 久久免费精品日本久久中文字幕| 亚洲一区二区在线看| 欧美成人精品在线视频| 久久亚洲二区| 国产欧美三级| 欧美在线|欧美| 噜噜噜久久亚洲精品国产品小说| 国模叶桐国产精品一区| 久久不射中文字幕| 久久久久国色av免费观看性色| 久久亚洲风情| 久久久久久久久久久久久女国产乱| 欧美午夜美女看片| 亚洲视频免费看| 欧美一区二区三区成人| 国产欧美在线视频| 欧美在线日韩| 欧美福利精品| 亚洲精品在线观| 国产精品成人v| 性8sex亚洲区入口| 欧美激情区在线播放| 亚洲人在线视频| 欧美日韩视频在线一区二区观看视频| 亚洲九九精品| 欧美在线亚洲一区| 亚洲国产精品电影在线观看| 欧美极品影院| 性欧美video另类hd性玩具| 男女精品视频| 亚洲欧美久久久| 在线观看欧美黄色| 欧美日韩亚洲高清一区二区| 亚洲欧美在线aaa| 欧美成人a∨高清免费观看| 中日韩午夜理伦电影免费| 国模叶桐国产精品一区| 欧美日韩国产综合视频在线| 午夜伦理片一区| 亚洲电影免费观看高清| 午夜精品久久| 亚洲美女中文字幕| 国内精品久久久久影院薰衣草| 欧美成人精精品一区二区频| 日韩午夜在线观看视频| 美女图片一区二区| 亚洲欧美成人综合| 亚洲青色在线| 国产精品日韩精品| 免费人成网站在线观看欧美高清 | 亚洲综合欧美日韩| 在线观看成人网| 国产精品久久久久久久久久ktv| 久久久久久综合网天天| 欧美国产精品中文字幕| 一区二区三区精品国产| 久久这里只有精品视频首页| 欧美顶级少妇做爰| 久久精品视频免费观看|