游戲服務(wù)器到底該選哪種網(wǎng)絡(luò)協(xié)議?(1)

原文地址:https://blog.csdn.net/erlib/article/details/24430493

在編寫網(wǎng)絡(luò)游戲的時候欢揖,到底使用UDP還是TCP的問題遲早都要面對。

一般來說你會聽到人們這樣說:“除非你正在寫一個動作類游戲,否則你就用TCP吧” 或者是 “你能夠在MMO游戲中用TCP,因為魔獸世界就用的TCP屑柔!”

遺憾的是,這些觀點(diǎn)都沒有反映這個問題的復(fù)雜性珍剑。

背景

首先掸宛,說明一下,我之前主要是用TCP進(jìn)行網(wǎng)絡(luò)編程招拙。我曾為一個流行的在線紙牌游戲編寫服務(wù)器了好幾年唧瘾,在高峰期我們的每臺服務(wù)器能夠承受4000到10000個連接(同一臺物理機(jī)器上有多個服務(wù)器進(jìn)程在跑)都沒有問題。在我來看别凤,TCP是一種安全而且常見的選擇饰序。

盡管如此,我們最新的項目卻是使用UDP協(xié)議闻妓,而且我們的項目無法通過任何方式在TCP下工作。事實上掠械,項目一開始使用的TCP由缆,但是后來發(fā)現(xiàn)我們使用TCP無法達(dá)到我們需求的連接數(shù)量時注祖,我們只能換成UDP了。

在使用中TCP表現(xiàn)怎么樣呢

從原理上均唉,TCP的優(yōu)勢有:

  • 簡單直接的長連接
  • 可靠的信息傳輸
  • 數(shù)據(jù)包的大小沒有限制

任何一個和TCP打過交道的人都知道是晨,要實現(xiàn)一個穩(wěn)定的TCP網(wǎng)絡(luò)連接,需要處理各種隱藏的坑舔箭,比如斷線檢測罩缴、慢速客戶端響應(yīng)阻塞數(shù)據(jù)包,對開放連接的各種dos攻擊层扶,阻塞和非阻塞IO模型等等箫章。

除了上面列出的這些問題外,一個好的TCP模塊確實不好編碼實現(xiàn)镜会。

但是檬寂,TCP最糟糕的特性是它對阻塞的控制。一般來說戳表,TCP假定丟包是由于網(wǎng)絡(luò)帶寬不夠造成的桶至,所以發(fā)生這種情況的時候,TCP就會減少發(fā)包速度匾旭。

在3G或WiFi下镣屹,一個數(shù)據(jù)包丟失了,你希望的是立馬重發(fā)這個數(shù)據(jù)包价涝,然而TCP的阻塞機(jī)制卻完全是采用相反的方式來處理女蜈!

而且沒有任何辦法能夠繞過這個機(jī)制,因為這是TCP協(xié)議構(gòu)建的基礎(chǔ)飒泻。這就是為什么在3G或者WiFi環(huán)境下鞭光,ping值能夠上升到1000多毫秒的原因。

為什么不用UDP

UDP相對TCP來說既簡單又困難泞遗。

舉個例子來說惰许,UDP是基于數(shù)據(jù)包構(gòu)建,這意味著在某些方面需要你完全顛覆在TCP下的觀念史辙。UDP只使用一個socket進(jìn)行通信汹买,不像TCP需要為每一個客戶端建立一個socket連接。這些都是UDP非常不錯的地方聊倔。

但是晦毙,大多數(shù)情況下你需要的僅僅是一些連接的概念罷了,一些基本的包序功能耙蔑,以及所謂的連接可靠性见妒。可惜的是甸陌,這些功能UDP都沒有辦法簡單的提供給你须揣,而你使用TCP卻都可以免費(fèi)得到盐股。

這也是人們?yōu)槭裁唇?jīng)常推薦TCP的原因。在用TCP的時候你可以不考慮這些問題耻卡,直到你需要同步連接的數(shù)量級達(dá)到500以上的時候疯汁。

所以,是的卵酪,UDP沒有提供所有的解決方法幌蚊,但是就像你看到的那樣,這也正是UDP好用的地方溃卡。在某種意義上來說溢豆,TCP對UDP就好比是Hibernate和手寫SQL的區(qū)別。

使用TCP失敗的地方

人們經(jīng)常給你建議塑煎,讓你去使用TCP沫换,比如“TCP跟UDP一樣快”或者“游戲X用TCP如此成功,所以TCP當(dāng)然是首選”最铁,然而讯赏,他們完全沒有理解為什么在那個特定的游戲中TCP是有效的,為什么UDP不按照順序發(fā)送數(shù)據(jù)包呢冷尉?

那么為什么魔獸世界采用TCP呢漱挎?首先我們需要解釋這個問題。這個問題其實是“為什么魔獸世界有的時候1000毫秒以上的延遲還能夠運(yùn)行雀哨?”這是TCP的性質(zhì)決定的磕谅,在發(fā)生丟包的時候,會產(chǎn)生巨大的延遲雾棺,因為TCP首先會去檢測哪些包發(fā)生了丟失膊夹,然后重發(fā)所有丟失的包,直到他們都被接收到捌浩。

可靠的UDP也是有延遲的放刨,但是由于它是在UDP的基礎(chǔ)之上建立的通信協(xié)議,所以可以通過多種方式來減少延遲尸饺,不像TCP进统,所有的東西都要依賴于TCP協(xié)議本身而無法被更改。

就這一點(diǎn)來講浪听,一些人要開始提到Nagle算法了螟碎,實際上它是你在實現(xiàn)任意一個對延遲敏感的TCP模型時首先需要禁止使用的。

那么魔獸世界以及其他的一些游戲是怎么處理延遲問題的呢迹栓?

方法也很簡單掉分,他們能夠隱藏掉延遲帶來的影響。

在魔獸世界中,玩家和玩家是無法碰撞的:因為這類碰撞是無法通過一些預(yù)測來處理的酥郭,但是玩家和環(huán)境之間的碰撞卻是可以通過預(yù)測來處理的尔崔,所以這里使用TCP是沒有問題的。

我們來看一下魔獸世界的戰(zhàn)斗就會發(fā)現(xiàn)褥民,玩家的攻擊指令發(fā)送給服務(wù)器的操作是放在比如“attack_entity(entity_id)”或者”cast_spell(entity_id, spell_id)“的接口中來做的,換句話說洗搂,瞄準(zhǔn)操作是獨(dú)立于進(jìn)行的消返。如此一來,一些類似發(fā)起攻擊動作和釋放技能特效就能夠在沒有收到服務(wù)器確認(rèn)的情況下就直接執(zhí)行耘拇,比如展現(xiàn)冰凍技能的效果就可以在服務(wù)器沒有返回數(shù)據(jù)前在客戶端就做出來撵颊。

客戶端直接開始進(jìn)行計算而不等待服務(wù)端確認(rèn)是一種典型的隱藏延遲的技術(shù)。

幾年前惫叛,我為一個叫“Five Card Jazz”的紙牌游戲編寫過客戶端倡勇。它使用的是http協(xié)議,它比直接的TCP協(xié)議連接的延遲更加嚴(yán)重嘉涌。

我們用簡單的紙牌繪制和抽牌的動畫來掩蓋延遲的問題妻熊,所以延遲的問題只在非常糟糕的連接下才會被看出來。這種方法也非常的典型:發(fā)送請求的同時開始播放牌桌的動畫仑最,一直播放翻動最后一張牌直到接收到了服務(wù)端傳回來的數(shù)據(jù)為止扔役。魔獸世界的戰(zhàn)斗特效就是使用類似的原理。

這也意味著警医,我們到底是使用TCP還是UDP取決于我們能否隱藏延遲亿胸。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市预皇,隨后出現(xiàn)的幾起案子侈玄,更是在濱河造成了極大的恐慌,老刑警劉巖吟温,帶你破解...
    沈念sama閱讀 211,639評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件序仙,死亡現(xiàn)場離奇詭異,居然都是意外死亡溯街,警方通過查閱死者的電腦和手機(jī)诱桂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來呈昔,“玉大人挥等,你說我怎么就攤上這事〉涛玻” “怎么了肝劲?”我有些...
    開封第一講書人閱讀 157,221評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我辞槐,道長掷漱,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,474評論 1 283
  • 正文 為了忘掉前任榄檬,我火速辦了婚禮卜范,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘鹿榜。我一直安慰自己海雪,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評論 6 386
  • 文/花漫 我一把揭開白布舱殿。 她就那樣靜靜地躺著奥裸,像睡著了一般。 火紅的嫁衣襯著肌膚如雪沪袭。 梳的紋絲不亂的頭發(fā)上湾宙,一...
    開封第一講書人閱讀 49,816評論 1 290
  • 那天,我揣著相機(jī)與錄音冈绊,去河邊找鬼侠鳄。 笑死,一個胖子當(dāng)著我的面吹牛死宣,可吹牛的內(nèi)容都是我干的畦攘。 我是一名探鬼主播,決...
    沈念sama閱讀 38,957評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼十电,長吁一口氣:“原來是場噩夢啊……” “哼知押!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起鹃骂,我...
    開封第一講書人閱讀 37,718評論 0 266
  • 序言:老撾萬榮一對情侶失蹤台盯,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后畏线,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體静盅,經(jīng)...
    沈念sama閱讀 44,176評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評論 2 327
  • 正文 我和宋清朗相戀三年寝殴,在試婚紗的時候發(fā)現(xiàn)自己被綠了蒿叠。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,646評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡蚣常,死狀恐怖市咽,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情抵蚊,我是刑警寧澤施绎,帶...
    沈念sama閱讀 34,322評論 4 330
  • 正文 年R本政府宣布溯革,位于F島的核電站,受9級特大地震影響谷醉,放射性物質(zhì)發(fā)生泄漏致稀。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評論 3 313
  • 文/蒙蒙 一俱尼、第九天 我趴在偏房一處隱蔽的房頂上張望抖单。 院中可真熱鬧,春花似錦遇八、人聲如沸臭猜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至羹应,卻和暖如春揽碘,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背园匹。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評論 1 266
  • 我被黑心中介騙來泰國打工雳刺, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人裸违。 一個月前我還...
    沈念sama閱讀 46,358評論 2 360
  • 正文 我出身青樓掖桦,卻偏偏與公主長得像,于是被迫代替她去往敵國和親供汛。 傳聞我的和親對象是個殘疾皇子枪汪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評論 2 348

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

  • 原文地址: TCP在什么時候失效 一個采用TCP的游戲必須能夠處理好突發(fā)的延遲問題(紙牌客戶端就很典型,對突發(fā)性的...
    Caiaolun閱讀 1,319評論 0 0
  • 目錄 TCP協(xié)議的基本概念面向鏈接的服務(wù)可靠的服務(wù)序列號字節(jié)流傳輸 TCP協(xié)議數(shù)據(jù)段的格式TCP偽頭部 TCP協(xié)議...
    kirito_song閱讀 2,966評論 2 33
  • 1.這篇文章不是本人原創(chuàng)的怔昨,只是個人為了對這部分知識做一個整理和系統(tǒng)的輸出而編輯成的雀久,在此鄭重地向本文所引用文章的...
    SOMCENT閱讀 13,049評論 6 174
  • 計算機(jī)網(wǎng)絡(luò)概述 網(wǎng)絡(luò)編程的實質(zhì)就是兩個(或多個)設(shè)備(例如計算機(jī))之間的數(shù)據(jù)傳輸。 按照計算機(jī)網(wǎng)絡(luò)的定義趁舀,通過一定...
    蛋炒飯_By閱讀 1,215評論 0 10
  • 網(wǎng)絡(luò)編程 網(wǎng)絡(luò)編程對于很多的初學(xué)者來說赖捌,都是很向往的一種編程技能,但是很多的初學(xué)者卻因為很長一段時間無法進(jìn)入網(wǎng)絡(luò)編...
    程序員歐陽閱讀 2,009評論 1 37