`
chriszeng87
  • 浏览: 743332 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

TCP连接建立过程中为什么需要“三次握手”

阅读更多
传输控制协议(Transmission Control Protocol, TCP)是一种面向连接的、可靠的、基于字节流的运输层(Transport layer)通信协议。是专门为了在不可靠的互联网络上提供一个可靠的端到端字节流而设计的。互联网络与单个网络不同,因为互联网络的不同部分可能有着截然不同的拓扑、带宽、延迟、分组大小和其他参数。TCP的设计目标是能够动态的适应互联网络的这些特性,而且当面对多种失败的时候仍然能够健壮。
每一次TCP连接都需要三个阶段:连接建立、数据传送和连接释放。“三次握手”就发生在连接建立阶段。“三次握手”的具体过程网上有很多详解。可自行Google之。这里探讨的是——为什么需要“三次握手”。
我Google该问题答案后发现,网络上对于“三次握手”的过程都有很详细的描述,但对于为什么需要“三次握手”来建立连接却没有很好的答案。只能求助于书本了。
在谢希仁著《计算机网络》第四版中讲“三次握手”的目的是“为了防止已失效的连接请求报文段突然又传送到了服务端,因而产生错误”。在另一部经典的《计算机网络》一书中讲“三次握手”的目的是为了解决“网络中存在延迟的重复分组”的问题。这两种不用的表述其实阐明的是同一个问题。
谢希仁版《计算机网络》中的例子是这样的,“已失效的连接请求报文段”的产生在这样一种情况下:client发出的第一个连接请求报文段并没有丢失,而是在某个网络结点长时间的滞留了,以致延误到连接释放以后的某个时间才到达server。本来这是一个早已失效的报文段。但server收到此失效的连接请求报文段后,就误认为是client再次发出的一个新的连接请求。于是就向client发出确认报文段,同意建立连接。假设不采用“三次握手”,那么只要server发出确认,新的连接就建立了。由于现在client并没有发出建立连接的请求,因此不会理睬server的确认,也不会向server发送数据。但server却以为新的运输连接已经建立,并一直等待client发来数据。这样,server的很多资源就白白浪费掉了。采用“三次握手”的办法可以防止上述现象发生。例如刚才那种情况,client不会向server的确认发出确认。server由于收不到确认,就知道client并没有要求建立连接。”
这个例子很清晰的阐释了“三次握手”对于建立可靠连接的意义。
在Google Groups的TopLanguage中看到一帖讨论TCP“三次握手”觉得很有意思。贴主提出“TCP建立连接为什么是三次握手?”的问题,在众多回复中,有一条回复写道:“这个问题的本质是, 信道不可靠, 但是通信双发需要就某个问题达成一致. 而要解决这个问题,  无论你在消息中包含什么信息, 三次通信是理论上的最小值. 所以三次握手不是TCP本身的要求, 而是为了满足"在不可靠信道上可靠地传输信息"这一需求所导致的. 请注意这里的本质需求,信道不可靠, 数据传输要可靠. 三次达到了, 那后面你想接着握手也好, 发数据也好, 跟进行可靠信息传输的需求就没关系了. 因此,如果信道是可靠的, 即无论什么时候发出消息, 对方一定能收到, 或者你不关心是否要保证对方收到你的消息, 那就能像UDP那样直接发送消息就可以了.”。这可视为对“三次握手”目的的另一种解答思路。
 
分享到:
评论

相关推荐

    tcp协议三次握手过程

    TCP 协议三次握手过程详解 TCP(Transmission Control Protocol)传输控制协议是指建立一个可靠的连接服务,采用三次握手确认建立一个连接。三次握手过程是 TCP 协议的核心部分,保证了数据传输的可靠性和正确性。 ...

    TCP三次握手PPT课件.ppt

    描述中提到的“TCP三次握手”是TCP连接建立的关键步骤,确保双方都能正确地接收到对方的初始化序列号,并确认通信能力,从而避免了数据丢失或错误的情况。 在TCP三次握手过程中: 1. **第一次握手**:客户端...

    TCP协议三次握手过程分析

    - **防止已失效的连接请求报文段突然又传送到服务器**:在三次握手中,服务器不会立即接受客户端的连接请求,而是先进行确认,然后再接受,这样可以有效避免因网络延迟等原因导致的失效请求报文被服务器误处理。...

    TCP三次握手.docx

    在第三次握手中,客户端收到服务器的 SYN-ACK 报文后,客户端会发送一个 ACK 报文给服务器,ACK 报文的序列号是 K+1,表示客户端已经收到服务器的 SYN 报文。客户端的状态变为 ESTABLISHED,表示客户端已经建立了与...

    Wireshark入门 tcp三次握手

    TCP三次握手是指在TCP连接建立过程中,客户端与服务器之间进行的一种交互过程。该过程由三个阶段组成: 1. **第一次握手**:客户端向服务器发起连接请求。 2. **第二次握手**:服务器确认接收到客户端的请求,并...

    TCP/IP的三次握手建立连接(带图释)

    在TCP/IP的连接建立过程中,三次握手是至关重要的步骤。这一过程确保了双方都能正确接收和理解彼此的连接请求,从而建立起可靠的通信链路。下面详细解析三次握手的过程: 1. **第一次握手**:客户端(如图中的...

    TCP三次握手

    TCP三次握手,TCP三次握手是TCP连接建立过程的可靠性保证

    TCP三次握手与四次挥手.pdf

    通过这三次握手,TCP连接的双方都能确认对方的发送和接收能力是正常的。 接下来,分析TCP四次挥手的过程: 1. 第一次挥手:当客户端完成数据发送任务后,发送一个带有FIN(结束)标志的数据包给服务器端,表示...

    wireshark抓包分析tcp三次握手四次挥手

    在TCP/IP通信中,TCP连接的建立和关闭过程分别称为三次握手和四次挥手,这两个过程对于理解TCP连接的工作原理至关重要。 首先,我们来详细讲解TCP的三次握手过程: 1. **第一次握手**:客户端(Client)发送一个...

    tcp3次握手实验报告

    捕获TCP连接的过程的数据包。 2)分析三次握手建立TCP连接的过程,描述数据包序列图。(包括 SYN标志和SEQ值) 1)检查FTP交互数据报文中用户名和密码是否用明文传送

    tcp3次握手建立连接 4次握手关闭连接

    TCP是一个面向连接的协议,所以在连接双方发送数据之前,都需要首先建立一条连接。TCP连接的建立可以简单的称为三次握手,而连接的中止则可以叫做四次握手。

    tcp三次握手

    ### TCP三次握手详解 #### 一、TCP协议概述 TCP(Transmission Control Protocol)是一种面向连接的、可靠的、基于字节流的传输层通信协议。它通过三次握手建立连接,确保了两端之间的通信能够准确无误地进行。 #...

    TCP协议三次握手示意图

    在提供的文件中,`TCP协议三次握手示意图.gif`和`TCP协议三次握手.vsd`应该是展示这个过程的图形化表示。`.gif`文件可能是一个动态图像,直观地展示了三次握手的过程,而`.vsd`文件则可能是Visio绘制的详细流程图,...

    验证tcp的三次握手

    在 TCP 连接建立和释放过程中,需要经过三次握手和四次握手来确保连接的可靠性和完整性。 一、TCP 三次握手过程 TCP 三次握手过程是指在客户端和服务器之间建立连接时,需要经过三次交互来确认连接的建立。这个...

    tcp三次握手与四次握手及SOCKE函数对应

    TCP通过“三次握手”和“四次握手”的过程来确保连接的建立和终止是可靠和有序的。同时,这些过程与编程中的socket函数紧密相关,帮助开发者在应用程序中实现网络通信。 首先,我们来看“TCP三次握手”。当两个设备...

    TCP报文分析--三次握手 四次挥手

    在 TCP 报文分析中,面向连接是指在数据传输之前,通信双方需要建立连接,这个连接是通过三次握手建立的。 TCP 报文头部结构 TCP 报文头部结构是 TCP 报文分析的基础,它包括源端口、目的端口、序列号、确认号、...

    案例测试TCP的三次握手和四次挥手过程

    三次握手是TCP连接建立的过程,它确保了双方都有能力发送和接收数据。以下是三次握手的详细步骤: 1. 第一次握手:客户端向服务器发送一个SYN(同步序列号)包,其中包含了客户端随机选择的初始序列号ISN。此时,...

    tcp三次握手协议

    TCP的三次握手是建立可靠连接的重要过程,它确保了两个通信端点都能正确理解对方的意图,避免了数据丢失或重复发送的问题。 首次握手:在TCP连接建立之初,客户端会发送一个带有SYN(同步序列编号)标志的数据包给...

Global site tag (gtag.js) - Google Analytics