tcp建立連接為什么需要三次握手

這是一個看似很“簡單”的問題,但貌似并沒有一個官方統一的答案。搜索了相關的資料,列舉出一些答案。

以下部分轉載自:tcp建立連接為什么需要三次握手

  • 在《計算機網絡》一書中其中有提到,三次握手的目的是“為了防止已經失效的連接請求報文段突然又傳到服務端,因而產生錯誤”,這種情況是:一端(client)A發出去的第一個連接請求報文并沒有丟失,而是因為某些未知的原因在某個網絡節點上發生滯留,導致延遲到連接釋放以后的某個時間才到達另一端(server)B。本來這是一個早已失效的報文段,但是B收到此失效的報文之后,會誤認為是A再次發出的一個新的連接請求,于是B端就向A又發出確認報文,表示同意建立連接。如果不采用“三次握手”,那么只要B端發出確認報文就會認為新的連接已經建立了,但是A端并沒有發出建立連接的請求,因此不會去向B端發送數據,B端沒有收到數據就會一直等待,這樣B端就會白白浪費掉很多資源。如果采用“三次握手”的話就不會出現這種情況,B端收到一個過時失效的報文段之后,向A端發出確認,此時A并沒有要求建立連接,所以就不會向B端發送確認,這個時候B端也能夠知道連接沒有建立。(知乎上對上面的解釋的評論:這個解答不是問題的本質,這個課本很多知識比較片面。問題的核心在于保證信道數據傳輸的可靠性,避免資源浪費僅僅是一個小的弱原因,不重要。)
    這里寫圖片描述

  • 問題的本質是,信道是不可靠的,但是我們要建立可靠的連接發送可靠的數據,也就是數據傳輸是需要可靠的。在這個時候三次握手是一個理論上的最小值,并不是說是tcp協議要求的,而是為了滿足在不可靠的信道上傳輸可靠的數據所要求的。

我們再來考慮,如果不是三次握手會出現什么情況呢:

假設有A和B兩端要進行通信,
1, 第一次:首先A發送一個(SYN)到B,意思是A要和B建立連接進行通信;

如果是只有一次握手的話,這樣肯定是不行的,A壓根都不知道B是不是收到了這個請求。
2, 第二次:B收到A要建立連接的請求之后,發送一個確認(SYN+ACK)給A,意思是收到A的消息了,B這里也是通的,表示可以建立連接;

如果只有兩次通信的話,這時候B不確定A是否收到了確認消息,有可能這個確認消息由于某些原因丟了。
3, 第三次:A如果收到了B的確認消息之后,再發出一個確認(ACK)消息,意思是告訴B,這邊是通的,然后A和B就可以建立連接相互通信了;

這個時候經過了三次握手,A和B雙方確認了兩邊都是通的,可以相互通信了,已經可以建立一個可靠的連接,并且可以相互發送數據。
4, 第四次:這個時候已經不需要B再發送一個確認消息了,兩邊已經通過前三次建立了一個可靠的連接,如果再發送第四次確認消息的話,就浪費資源了。

如果第二個報文段B發出的(SYN+ACK)分別發送的話,也是可以理解為四次,但是被優化了,一起發送了。
超時重傳機制,

(1) 如果第一個包,A發送給B請求建立連接的報文(SYN)如果丟掉了,A會周期性的超時重傳,直到B發出確認(SYN+ACK);
(2) 如果第二個包,B發送給A的確認報文(SYN+ACK)如果丟掉了,B會周期性的超時重傳,直到A發出確認(ACK);
(3) 如果第三個包,A發送給B的確認報文(ACK)如果丟掉了,

A在發送完確認報文之后,單方面會進入ESTABLISHED的狀態,B還是SYN_RCVD狀態
如果此時雙方都沒有數據需要發送,B會周期性的超時發送(SYN+ACK),直到收到A的確認報文(ACK),此時B也進入ESTABLISHED狀態,雙方可以發送數據;
如果A有數據發送,A發送的是(ACK+DATA),B會在收到這個數據包的時候自動切換到ESTABLISHED狀態,并接受數據(DATA);
如果這個時候B要發送數據,B是發送不了數據的,會周期性的超時重傳(SYN+ACK)直到收到A的確認(ACK)B才能發送數據。
三次握手牽扯到的狀態轉換

LISTEN 表示socket已經處于listen狀態了,可以建立連接;
SYN_SENT 表示socket在發出connect連接的時候,會首先發送SYN報文,然后等待另一端發送的確認報文(ACK),表示這端已經發送完SYN報文了;
SYN_RCVD 表示一端已經接收到SYN報文了;
ESTABLISHED 表示已經建立連接了,可以發送數據了。

這里寫圖片描述

作者:朋克雪球兔
鏈接:https://www.zhihu.com/question/24853633/answer/200721662
來源:知乎
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。

看了很多答案,只有一個答案提到“兩軍問題”,其他的答案,長篇累牘或者抖機靈感覺都沒回答到點子上。其實兩次四次四十次,在工程上都是可以接受的。如果讓我設計一個非常重要,對可靠性要求很高的通訊協議,我也完全可能采用更多次握手的設計。亦或者涉及對實時性要求很高的通訊,也完全可以設計成不握手(udp)的協議。TCP之所以使用三次握手,完全是一種為了解決“兩軍問題”所采用的折衷的設計。所謂“兩軍問題”,就是紅軍想告訴藍軍明天下午一起對敵開火,那么紅軍會派信使1號跑過去告訴藍軍,藍軍收到消息再派信使2號告訴紅軍收到,注意,這時藍軍并不知道紅軍是否收到藍軍的回復。因此需要紅軍收到回復再派信使3號告訴藍軍收到回復,而此時紅軍也不知道藍軍是否收到回復,因此藍軍收到信使3號的消息再派信使4號…可以看到,由于信息有可能丟失,為了保證信息傳達的確定性,我們需要進行很多次傳遞。互相通信的次數越多,那么這個信息傳遞到的概率就越大。tcp采用三次握手,就是為了盡可能可靠,然而,這也僅是一種選擇。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/450076.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/450076.shtml
英文地址,請注明出處:http://en.pswp.cn/news/450076.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

SFTPUtils工具類及使用

配置maven <dependency><groupId>com.jcraft</groupId><artifactId>jsch</artifactId><version>0.1.54</version> </dependency> 工具類 package com.sftp;import com.jcraft.jsch.*; import com.jcraft.jsch.ChannelSftp.LsE…

國內手機產業混亂:產業一窩蜂 企業撈快錢

對于當前國內手機行業的現狀&#xff0c;本報記者采訪的多位業內人士表示&#xff0c;目前國內手機行業仍是“紅海”格局&#xff0c;多數企業并不了解手機產業規律&#xff0c;看到有錢賺就“一窩蜂”上項目。有行業人士認為&#xff0c;要走出目前行業的現狀&#xff0c;企業…

查看私密文章方法

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 我只是記錄下&#xff0c;曾經寫過一次文章&#xff0c;勾選了私密&#xff0c;再后來就找不到了。 下面這個鏈接可以查出那篇文章&…

SDUT-3364_歐拉回路

數據結構實驗之圖論八&#xff1a;歐拉回路 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 在哥尼斯堡的一個公園里&#xff0c;有七座橋將普雷格爾河中兩個島及島與河岸連接起來。 能否走過這樣的七座橋&#xff0c;并且每橋只走一次&#xff1f;瑞士數學…

Tcp三次握手和四次揮手狀態圖

三次握手 四次揮手 正常情況下 同時揮手 SYN攻擊&#xff1a; 在三次握手過程中&#xff0c;Server發送SYN-ACK之后&#xff0c;收到Client的ACK之前的TCP連接稱為半連接&#xff08;half-open connect&#xff09;&#xff0c;此時Server處于SYN_RCVD狀態&#xff0c;當…

QEMU 3.0.0 新特性一覽

QEMU 在 2018年8月15發布了版本3.0.0&#xff0c; 正式從 2.12 進入了3.0 時代。 而且到今年位為止&#xff0c;QEMU 已經有15個年頭了&#xff0c;出乎意料的長阿&#xff0c;:) 其主要新特性如下&#xff1a; ARM&#xff1a; 在virt機器中支持SMMUv3 IOMMU 在v8M中支持VLLDM…

OpenCL、OpenGL 同時工作

視頻處理如果能使用OpenCL、OpenGL、omap將大量提高運算速度&#xff0c;簡單介紹OpenCL、OpenGL 同時工作。 OpenCL和OpenGL都能用于操作GPU&#xff0c;但是前者主要用于通用計算&#xff0c;而后者主要用于圖像渲染。在某些情況下&#xff0c;我們希望能用OpenCL計得到算圖像…

財務自由之路——為什么選擇淘寶(下)

接上文~一、淘寶之前的大佬們是怎么試錯的?我們看看在淘寶之前的大佬們是怎么試錯迭代產品的。都知道飛機是萊特兄弟發明的&#xff0c;但很少有人知道為什么是他們。在內燃機發明后的很長一段時間內全球各地發明家都在投入研究飛機&#xff0c;萊特兄弟相對于其他競爭者&…

java參數后面跟三個點是什么意思

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 AVA中類型后面跟三個點是什么來的。 看代碼中那個三點&#xff0c;這樣做起到重載的作用&#xff0c;但這是什么意思&#xff1f; cla…

一只視頻程序猿的移動直播SDK初體驗

本文轉自一只視頻程序猿的移動直播SDK初體驗&#xff0c;此處僅做排版改動。 今早老板召開站會&#xff0c;“移動直播這么火&#xff0c;市面上有一百多個APP&#xff0c;小斌&#xff0c;你下周交個原型APP瞅瞅!” 小弟心中一萬匹草泥馬奔過&#xff0c;這玩意兒哪兒是幾天就…

Xilinx zynq-7000系列FPGA移植Linux操作系統詳細教程

Xilinx zynq-7000系列FPGA移植Linux操作系統詳細教程 一&#xff1a;前言 最近手上壓了一塊米聯客的Miz7035&#xff0c;一塊xilinx zynq-7000系列的開發板&#xff0c;想著正好學習一下linux在ARM9上的移植&#xff0c;網上基本都是ZC702、zed的教程&#xff0c;這對于買了非標…

程序員的創業困境 誰來幫助出出主意?

【編者按】有人說&#xff0c;程序員是吃青春飯的&#xff0c;到一定年齡就得考慮轉行&#xff0c;也有人選擇自己創業。而當創業使你偏離了之前持續學習專業知識的軌道時&#xff0c;你會選擇在創業路上繼續堅持還是回歸自己的老本行&#xff1f;編程編了十幾年的Dan McComas半…

節選—Android 視頻直播 ( 從快播到直播,從高清到無碼 )十年視頻開發項目

本文轉載自Android 視頻直播 &#xff08; 從快播到直播&#xff0c;從高清到無碼 )十年視頻開發項目&#xff0c;截取其中技術概念比較相關的部分&#xff0c;并做了重新的排版。 視頻和直播的準備&#xff1a; android-java層&#xff1a;camera相關&#xff08;視頻&#x…

getDeclaredMethod和getMethod的區別

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 getDeclaredMethod*()獲取的是類自身聲明的所有方法&#xff0c;包含public、protected和private方法。getMethod*()獲取的是類的所有共有…

12.5PMP試題每日一題

在什么情況下項目正式受控于實施整體變更控制過程&#xff1a;A、從項目啟動到收尾的所有過程B、只有當項目基準建立之后C、在項目基準建立之前D、只要有人提起變更請求的時候 作者&#xff1a;Tracy19890201&#xff08;同微信號&#xff09; 答案將于明天和新題一起揭曉&…

在線預覽word,excel文檔

Google Doc 示例&#xff1a;https://jsfiddle.net/7xr419yb/ Microsoft Office 示例&#xff1a;https://jsfiddle.net/gcuzq343/轉載于:https://www.cnblogs.com/alexguoyihao/p/10314626.html

如何遷移整個git倉庫

轉自準備更換git托管&#xff0c;如何遷移原git倉庫一個回答 如果你想從別的 Git 托管服務那里復制一份源代碼到新的 Git 托管服務器上的話&#xff0c;可以通過以下步驟來操作。 從原地址克隆一份裸版本庫&#xff0c;比如原本托管于 GitHub。 git clone –bare git://githu…

關于創業:希望有人在N年前就告訴我的一些事兒

【編者按】原文作者為前微軟員工、創業家Amir Khella&#xff0c;他離開微軟后開始自主創業&#xff0c;并成功創辦了多家公司。他經常在博客中分享自己的創業故事和經驗。以下是其中一篇博文&#xff0c;他認為創業者想要成功&#xff0c;首先需要找到自己的方向&#xff0c;再…

Rust核心團隊前成員Brian Anderson加入PingCAP

昨天&#xff0c;國內新型分布式數據庫公司PingCAP聯合創始人兼CEO劉奇在朋友圈宣布&#xff0c;Rust核心團隊前成員Brian Anderson將加入公司。PingCAP聯合創始人兼CTO黃東旭進一步向InfoQ記者證實了此消息&#xff0c;并透露Brian將從事TiKV相關的工作&#xff0c;從存儲引擎…

JeeSite 是什么、概述

見JeeSite官網&#xff1a;http://jeesite4.mydoc.io/ 前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 總體概述 快速訪問 JeeSite 官網地址&#xff1a;http://jeesite.comJeeSite 在…