Socket粘包和拆包處理思路

一旦客戶端和服務器建立了Socket通信連接,接下來粘包和拆包就是一個必須要考慮的問題

本文是關(guān)于使用TCP協(xié)議下Socket粘包和拆包的處理思路

一個大前提:TCP協(xié)議是可靠的,數(shù)據(jù)包一定會到達(99.9%的情況下),而且是按順序到達,所以就不需要考慮UDP協(xié)議丟包和亂序的問題

一個小前提:TCP協(xié)議會根據(jù)數(shù)據(jù)包的大小和網(wǎng)絡通訊狀況對數(shù)據(jù)包合并發(fā)送或分片(分包),一個重要的嘗試就是大于MTU值的數(shù)據(jù)包一定會被分割震庭,因此當數(shù)據(jù)包到達時會出現(xiàn)兩種情況:1、和其他數(shù)據(jù)包的一部分或者整體連成一個大包你雌,2:被分割成幾個小包先后到達

因此器联,為了確定每個包的起始位置,需要在要發(fā)送的數(shù)據(jù)前面加上包頭匪蝙,包頭里一般記錄了數(shù)據(jù)的長度,復雜一點了要加上壓縮標志位和CRC校驗位等信息习贫,以便于檢錯逛球。更嚴格的情況下還會加上包尾

首先從緩沖流中讀取一個包頭的長度(假設是4個字節(jié)),如果連一個包頭都讀不出來,要么是連接中斷了(處理異常苫昌,檢查心跳颤绕,進入超時等待),要么是網(wǎng)絡有延遲需要繼續(xù)接收

解析包頭數(shù)據(jù)祟身,得到包體長度

進入讀取循環(huán)

判斷緩沖流中剩余的數(shù)據(jù)長度是否大于包體長度

大于等于(粘包的情況)奥务,則讀取一個包體,然后將緩沖流清空袜硫,將剩余數(shù)據(jù)寫回緩沖流(其實就是改變流指針的位置) 然后繼續(xù)讀取下一個包頭

小于(被拆分了)氯葬,則跳出讀取循環(huán),繼續(xù)等待下一次數(shù)據(jù)接收(可以是異步等待)

對于連接斷開婉陷,可以分為服務器知道客戶端斷開(客戶端主動用四次揮手和服務器斷開)帚称,和不知道客戶端斷開(拔網(wǎng)線),前一種情況走正常流程就可以了秽澳,后一種情況下有時鏈路層會通知網(wǎng)絡層闯睹,進而拋出異常,比如16001担神,處理之楼吃。可靠的做法還是使用心跳檢測,設定在若干秒后沒有收到心跳包,就由服務器主動結(jié)束這個連接

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末探入,一起剝皮案震驚了整個濱河市嘲叔,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌初厚,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,627評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異斩披,居然都是意外死亡溜族,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評論 3 399
  • 文/潘曉璐 我一進店門垦沉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來煌抒,“玉大人,你說我怎么就攤上這事厕倍」炎常” “怎么了?”我有些...
    開封第一講書人閱讀 169,346評論 0 362
  • 文/不壞的土叔 我叫張陵讹弯,是天一觀的道長况既。 經(jīng)常有香客問我,道長组民,這世上最難降的妖魔是什么棒仍? 我笑而不...
    開封第一講書人閱讀 60,097評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮臭胜,結(jié)果婚禮上莫其,老公的妹妹穿的比我還像新娘。我一直安慰自己耸三,他們只是感情好乱陡,可當我...
    茶點故事閱讀 69,100評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著仪壮,像睡著了一般憨颠。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上积锅,一...
    開封第一講書人閱讀 52,696評論 1 312
  • 那天烙心,我揣著相機與錄音,去河邊找鬼乏沸。 笑死淫茵,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的蹬跃。 我是一名探鬼主播匙瘪,決...
    沈念sama閱讀 41,165評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼蝶缀!你這毒婦竟也來了丹喻?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,108評論 0 277
  • 序言:老撾萬榮一對情侶失蹤翁都,失蹤者是張志新(化名)和其女友劉穎碍论,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體柄慰,經(jīng)...
    沈念sama閱讀 46,646評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡鳍悠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,709評論 3 342
  • 正文 我和宋清朗相戀三年税娜,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片藏研。...
    茶點故事閱讀 40,861評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡敬矩,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蠢挡,到底是詐尸還是另有隱情弧岳,我是刑警寧澤,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布业踏,位于F島的核電站禽炬,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏勤家。R本人自食惡果不足惜腹尖,卻給世界環(huán)境...
    茶點故事閱讀 42,196評論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望却紧。 院中可真熱鬧桐臊,春花似錦胎撤、人聲如沸晓殊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽巫俺。三九已至,卻和暖如春肿男,著一層夾襖步出監(jiān)牢的瞬間介汹,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評論 1 274
  • 我被黑心中介騙來泰國打工舶沛, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留嘹承,地道東北人。 一個月前我還...
    沈念sama閱讀 49,287評論 3 379
  • 正文 我出身青樓如庭,卻偏偏與公主長得像叹卷,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子坪它,可洞房花燭夜當晚...
    茶點故事閱讀 45,860評論 2 361

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