色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

【推薦】TCP為何粘包?粘包問題如何解決?

億佰特物聯(lián)網(wǎng)應(yīng)用專家 ? 2022-09-23 10:00 ? 次閱讀

我們在涉及TCP協(xié)議的應(yīng)用中,經(jīng)常會出現(xiàn)粘包的問題。所謂粘包,簡單地講,就是我有兩條消息,明明發(fā)送端的代碼是分兩次發(fā)送的,但是在接收端卻一次性就接收到了兩條消息。這個情況不管是在嵌入式行業(yè)還是在互聯(lián)網(wǎng)行業(yè),都非常的普遍。

TCP協(xié)議為什么粘包?

那就需要先了解 TCP 的定義。TCP(Transmission Control Protocol)傳輸控制協(xié)議,是一種面向連接的、可靠的、基于字節(jié)流的傳輸層通信協(xié)議。其中跟粘包關(guān)系最大的就是基于字節(jié)流這個特點。字節(jié)流可以理解為一個雙向的通道里流淌的數(shù)據(jù),這個數(shù)據(jù)其實就是我們常說的二進制數(shù)據(jù),簡單來說就是一大堆 01 串。這些 01 串之間沒有任何邊界。7dda0d04-3ab3-11ed-b180-dac502259ad0.png應(yīng)用層傳到 TCP 協(xié)議的數(shù)據(jù),不是以消息報為單位向目的主機發(fā)送,而是以字節(jié)流的方式發(fā)送到下游,這些數(shù)據(jù)可能被切割和組裝成各種數(shù)據(jù)包,接收端接收到這些數(shù)據(jù)包后沒有正確還原之前的消息,因此出現(xiàn)粘包現(xiàn)象。那為什么會出現(xiàn)不能正確還原的情況呢?主要有兩個方面的原因:

1. 發(fā)送端的原因發(fā)送端在組裝消息的時候,就把幾個小包合成一包了,這樣接收端自然無法解析出小包。這對應(yīng)的就是Nagle 算法。因為TCP和Nagle 算法都是上個世紀(jì)的產(chǎn)物了,在早期的網(wǎng)絡(luò)中這樣做,可以顯著地減小網(wǎng)絡(luò)的壓力。否則頻繁地發(fā)送僅有幾個字節(jié)的小包,會嚴重浪費網(wǎng)絡(luò)IO性能。但是在現(xiàn)代互聯(lián)網(wǎng)中,網(wǎng)絡(luò)性能已經(jīng)有了大幅提升,似乎Nagle 算法提升的那么一點IO性能就不是那么重要了,反而由于等待數(shù)據(jù)來合并的操作,會導(dǎo)致傳輸延遲變大,在網(wǎng)絡(luò)游戲應(yīng)用時,就會非常影響體驗。所以現(xiàn)在一般都會關(guān)掉它。2. 接收端的原因接收端接收到消息以后,應(yīng)用層總是不能立即取走數(shù)據(jù),總是會有接收緩沖區(qū)的存在。如果兩條獨立的消息進入緩沖區(qū)的間隔太小,應(yīng)用層不能在兩次消息中間取走上一條消息,那么下次讀取的時候,就勢必會把兩包消息同時讀出來,這也會導(dǎo)致粘包。7df3fdea-3ab3-11ed-b180-dac502259ad0.png

而且這個情況并不能通過讓發(fā)送端在時間上均勻發(fā)包來避免,因為網(wǎng)絡(luò)不穩(wěn)定情況的存在,即使是時間上均勻發(fā)送的數(shù)據(jù)包,在接收端看來也可能是隨機出現(xiàn)的。

如何規(guī)避粘包的負面影響?

根據(jù)以上分析,我們不難發(fā)現(xiàn),想要杜絕粘包的問題出現(xiàn),基本上是不可能的。即使發(fā)送端和接收端都能自己控制,但是網(wǎng)絡(luò)傳輸?shù)倪^程也是很難控制的。
但是即使粘包的問題存在,也不影響我們大規(guī)模的使用TCP協(xié)議。因為這個問題在應(yīng)用層非常好處理。大致有兩種思路:1. 在信息中加入特殊的標(biāo)志作為分隔符7e1858c0-3ab3-11ed-b180-dac502259ad0.png

這樣,當(dāng)應(yīng)用層檢測到特殊的分隔符后,便知道這是一包得到開始和結(jié)束,就可以進行分片等操作,問題便迎刃而解。不過這樣存在一些弊端。比如定義分隔符為“12345678”,那如果消息內(nèi)容里面出現(xiàn)“12345678”的字符串呢?這樣就會導(dǎo)致消息被異常的切片,導(dǎo)致接收到的消息錯誤。但假如自己能夠控制消息的內(nèi)容,保證里面不會出現(xiàn)“12345678”的內(nèi)容,則此方法較為靈活。2. 加入信息的長度7e2ec5e2-3ab3-11ed-b180-dac502259ad0.png根據(jù)約定好的長度的字段,讀取消息長度的信息,再根據(jù)消息長度信息讀取消息內(nèi)容。這也是一種非常常用的方法,在很多協(xié)議中都有體現(xiàn)。
3. 添加包首部發(fā)送端給每個數(shù)據(jù)包添加包首部,首部中應(yīng)該至少包含數(shù)據(jù)包的長度,這樣接收端在接收到數(shù)據(jù)后,就可以通過讀取包首部的長度字段,知道每一個數(shù)據(jù)包的實際長度。以上就是本期關(guān)于解決TCP粘包問題的內(nèi)容,小編碼字不易,求個點贊、分享、在看三連支持!我們下期見~~

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • TCP
    TCP
    +關(guān)注

    關(guān)注

    8

    文章

    1378

    瀏覽量

    79227
收藏 人收藏

    評論

    相關(guān)推薦

    華納云如何解讀WinMTR的丟率數(shù)據(jù)?

    是如何解讀WinMTR的丟率數(shù)據(jù): 1. 丟率的定義 丟率 :在一定時間內(nèi),未能成功到達目的地的數(shù)據(jù)占發(fā)送數(shù)據(jù)
    的頭像 發(fā)表于 12-30 16:51 ?150次閱讀

    Linux網(wǎng)卡收流程

    Linux 網(wǎng)卡收流程如下 網(wǎng)卡收到數(shù)據(jù) 將數(shù)據(jù)從網(wǎng)卡硬件緩存移動到服務(wù)器內(nèi)存中(DMA方式,不經(jīng)過CPU) 通過硬中斷通知CPU處理 CPU通過軟中斷通知內(nèi)核處理 經(jīng)過TCP/
    的頭像 發(fā)表于 12-05 16:21 ?265次閱讀
    Linux網(wǎng)卡收<b class='flag-5'>包</b>流程

    集成電路微組裝用環(huán)氧接膠樹脂析出及控制研究

    環(huán)氧接膠常用作集成電路接材料。在其固化過程中,經(jīng)常觀察到樹脂析出現(xiàn)象。樹脂析出物會沾污鍵合區(qū),帶來鍵合可靠性問題。本文利用接觸角的方法研究了樹脂析出的機理,討論了基板粗糙度和樹脂析出的關(guān)系,初步得出真空烘培對于樹脂析出有較大影響,而基板粗糙度和樹脂析出的嚴重程度無必然
    的頭像 發(fā)表于 11-05 10:16 ?296次閱讀

    CentOS中使用tcpdump抓

    CentOS中使用tcpdump抓
    的頭像 發(fā)表于 10-28 14:48 ?313次閱讀

    原來UV膠水在LED燈具接中有這么多用膠點

    燈具中的重要耗材,在燈具制造中膠粘劑在LED照明產(chǎn)品中,主要起到接、 密封、導(dǎo)熱、阻燃防護等功效。Chenlink作為國產(chǎn)UV膠水廠家,針對LED燈具也生產(chǎn)了一系列UV膠水,可用于玻璃接,塑料接以及金屬
    的頭像 發(fā)表于 07-26 09:23 ?754次閱讀

    esp8266讀取模擬數(shù)據(jù)并記錄到eeprom,發(fā)送tcp時無法讀取模擬如何解決?

    嗨,esp8266 讀取模擬數(shù)據(jù)并記錄到 eeprom,我正在將存儲在 eeprom 中的數(shù)據(jù)作為 tcp 發(fā)送,但在發(fā)送 tcp 時無法讀取模擬,如
    發(fā)表于 07-11 07:22

    為什么ESP8266 TCP透傳過程會丟

    為什么ESP8266 TCP透傳過程會丟
    發(fā)表于 07-09 07:55

    tcp_client例程為何去掉發(fā)送后,一直接收就會容易出現(xiàn)數(shù)據(jù)呢?

    / portTICK_PERIOD_MS);} 代碼如下,當(dāng)我使用tcp_client例程,并且把發(fā)送數(shù)據(jù)注釋掉,再接收數(shù)據(jù)就很容易出現(xiàn)TCP數(shù)據(jù),求助 [22:43:18.32
    發(fā)表于 06-17 07:47

    lwip tcp的原因?

    使用lwip協(xié)議棧,作為客戶端應(yīng)答2幀數(shù)據(jù)時,會有問題,在tcp write 后調(diào)用tcp output沒有效果,設(shè)置 #define TF_NODELAY((u8_t)0x40U
    發(fā)表于 05-10 06:51

    電池和硬電池的區(qū)別有哪些呢?

    電池和硬電池是兩種不同類型的鋰離子電池封裝方式,它們在材料、結(jié)構(gòu)、性能以及應(yīng)用領(lǐng)域上都存在顯著的區(qū)別。
    的頭像 發(fā)表于 05-07 10:25 ?1.1w次閱讀

    儲能電池ccs結(jié)構(gòu)介紹 儲能電池的結(jié)構(gòu)原理是什么?

    儲能電池CCS結(jié)構(gòu)介紹 儲能電池(Energy Storage Battery Pack,簡稱ESBP)是一種用于存儲電能的設(shè)備,廣泛應(yīng)用于電動汽車、可再生能源、電網(wǎng)調(diào)節(jié)等領(lǐng)域。儲能電池的結(jié)構(gòu)
    的頭像 發(fā)表于 04-29 14:32 ?2473次閱讀

    鋰電池軟和硬哪個好

    鋰電池作為現(xiàn)代電子設(shè)備和電動汽車的主要電源,其封裝形式主要分為軟和硬兩種。
    的頭像 發(fā)表于 04-28 17:22 ?7946次閱讀

    技術(shù)分享 | 芯片接空洞的超聲檢測

    隨著電子封裝技術(shù)向小型化發(fā)展,芯片散熱問題逐漸成為阻礙其具有高可靠性的瓶頸,特別是功率器件,芯片接空洞是造成器件散熱不良而失效的主要原因。因此,在對元器件的篩選檢測工作中,往往需要通過超聲檢測手段
    的頭像 發(fā)表于 04-11 11:48 ?1480次閱讀
    技術(shù)分享 | 芯片<b class='flag-5'>粘</b>接空洞的超聲檢測

    新能源汽車電池為何缺乏通用性?

    電池電壓又分為額定電壓、端電壓、開路電壓、負載電壓、最高充電電壓、最低放電電壓,這些都對電池的通用型造成很大影響。
    發(fā)表于 04-10 11:17 ?552次閱讀

    接層空洞對功率芯片熱阻的影響

    共讀好書 潘浩東 盧桃 陳曉東 何驍 鄒雅冰 (工業(yè)和信息化部電子第五研究所) 摘要: 采用有限元數(shù)值模擬方法,建立金氧半場效晶體管(MOSFET)三維有限元模型,定義不同大小和位置的接層空洞模型
    的頭像 發(fā)表于 02-02 16:02 ?653次閱讀
    <b class='flag-5'>粘</b>接層空洞對功率芯片熱阻的影響
    主站蜘蛛池模板: 免费特黄一区二区三区视频一 | 久久精品中文字幕 | 扒开胸罩揉她的乳尖视频 | DASD-700美谷朱里 | 亚州中文字幕 | 精品淑女少妇AV久久免费 | 97人人爽人人爽人人人片AV | 精品亚洲永久免费精品 | 亚洲国产成人爱AV在线播放丿 | 人妖干美女| 一本之道加勒比在线观看 | 99久久精品一区二区三区 | 国产午夜精品AV一区二区麻豆 | 中国农村妇女真实BBWBBWBBW | 99久久综合精品免费 | 国产精品99久久久久久AV色戒 | 国产成人免费片在线观看 | 另类欧美尿交 | 我半夜摸妺妺的奶C了她软件 | 欧美精品高清在线观看 | 狂野猛交xxxx吃奶 | 99RE6这里只有精品国产AV | 99E久热只有精品8在线直播 | 校草让我脱了内裤给全班看 | 免费99精品国产人妻自在线 | 又硬又粗又大一区二区三区视频 | 伊人久久精品线影院 | 日本漂亮妈妈7观整有限中 日本片bbbxxx | 手机看片一区二区 | 日本一区二区三区在线观看网站 | 九色91精品国产网站 | 午夜欧洲亚洲AV永久无码精品 | 国产欧美日韩精品a在线观看高清 | 国产h视频在线观看免费 | 草莓视频免费在线观看 | 蜜柚视频网在线观看免费 | 久久精品一卡二卡三卡四卡视频版 | 亚洲 在线 日韩 欧美 | 把腿张开再深点好爽宝贝 | 色多多深夜福利免费观看 | 久久综合网久久综合 |