python-tcp粘包

來源:互聯網
上載者:User

標籤:udp   長度   開啟   pytho   傳輸   size   串連   資料流   一個   

tcp有粘包,udp無粘包,將超出buffer_size資料丟棄。udp只負責發資料,不管服務端有沒有開啟(不依賴於服務端),一樣運行不報錯,所以不可靠。

tcp面向流,udp面向訊息報文,每個udp段都是一條訊息。應用程式必須以訊息為單位提取資料,不能一次提取任意位元組大小的資料。

udp不需建串連,所以能提供高效率服務。

tcp是基於資料流的(不知道起始位置和結束位置),於是收發的訊息不可為空,需要c/s兩端添加空白訊息處理機制,防止程式卡主,而udp是基於資料報的,即便輸入的是空格,那也不是空訊息,因為udp協議會封裝上訊息頭。

粘包兩種情況:

1)包小:面向流的通訊是沒有邊界保護的。tcp會將多次時間間隔小,資料量小的資料合成一個資料,當成一個包進行傳輸,這樣用戶端只能收到一個包。

2)包大:接收端從緩衝池接收小於包長度的固定資料大小,剩餘資料留在緩衝池,等待第二次接收發送端第二次發送的資料時接收到,造成粘包。

 

python-tcp粘包

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.