Java网络原理之连接管理:TCP三次握手和TCP四次挥手

问题:TCP为什么是三次握手?而不是两次或者四次?

TCP作为种可靠传输控制协议,其核心思想:既要保证数据可靠传输,又要提高传输的效率,而用三次恰恰可以满足以上两方面的需求!

  TCP可靠传输的精髓: TCP连接的 发送方A,由操作系统动态随机选取-个32位长的序列号(InitialSequence Number),假设A的初始序列号为1000,以该序列号为原点,对自己将要发送的每个字节的数据进行编号,1001, 1002, 100... 并把自己的初始序列号ISN告诉B,让B有一个思想准备,什么样编号的数据是合法的,什么编号是非法的,比如编号900就是非法的,同时B还可以对A每一个编号的字节数据进行确认。 如果A收到B确认编号为2001,则意味着字节编号为1001-2000,共1000个字节已经安全到达。

  同理B也是类似的操作,假设B的初始序列号ISN为2000, 以该序列号为原点,对自己将要发送的每个字节的数据进行编号,2001. 2002, 200....并把自己的初始序列号ISN告诉A,以便A可以确认B发送的每一 个字节。如果B收到A确认编号为4001,则意味着字节编号为2001-4000共2000个字节已经安全到达。

  一句话概括,TCP连接握手, 握的是啥?
通信双方数据原点的序列号。(ISN)

TCP为什么是四次挥手?(三次挥手/同时挥手)

因为TCP是全双工通信的
(1)第一次挥手
因此当主动方发送断开连接的请求(即FIN报文)给被动方时,仅仅代表主动方不会再发送数据报文了,但主动方仍可以接收数据报文。
(2)第二次挥手
被动方此时有可能还有相应的数据报文需要发送,因此需要先发送ACK报文,告知主动方“我知道你想断开连接的请求了”。这样主动方便不会因为没有收到应答而继续发送断开连接的请求(即FIN报文)。
(3)第三次挥手
被动方在处理完数据报文后,便发送给主动方FIN报文;这样可以保证数据通信正常可靠地完成。发送完FIN报文后,被动方进入LAST_ACK阶段(超时等待)。
(4)第四挥手
如果主动方及时发送ACK报文进行连接中断的确认,这时被动方就直接释放连接,进入可用状态。

原文地址:https://blog.51cto.com/14232658/2473340

时间: 2024-10-12 13:50:06

Java网络原理之连接管理:TCP三次握手和TCP四次挥手的相关文章

TCP三次握手及TCP连接状态 TCP报文首部格式

建立TCP连接时的TCP三次握手和断开TCP连接时的4次挥手整体过程如下图: 开个玩笑 ACK: TCP协议规定,只有ACK=1时有效,连接建立后所有发送的报文ACK必须为1 SYN(SYNchronization同步):在连接建立用来同步序号.当SYN=1而ACK=0时,表明这是一个连接请求报文.对方若同意建立连接,则应在响应报文中使用SYN=1 ACK=1因此,SYN置1表示这是一个连接请求或连接接受报文 FIN(FINIS)即完,终结的意思,用来释放一个连接.当FIN=1时,表明此报文段发

tcp ip三次握手链接和四次挥手断开

一 三次握手目的是为了建立连接... 1 核心的就是client端和service端,进行数据"报文" 交换 2 报文,目的是互相通知,确认链接 或 过程描述:::::: 1 首先Client端发送连接请求报文, 2 Server段接受连接后回复ACK报文,并为这次连接分配资源. 3 Client端接收到ACK报文后也向Server段发生ACK报文,并分配资源, 这样TCP连接就建立了. 二 数据socket传输 1 不断的往某ip 的某端口,写入数据 2 ip服务器上不断的监听该端口

1.tcp协议 三次握手建链接 四次挥手断开链接 tcp协议的状态 syn洪水攻击与半连接池 互联网协议详解 3. socket介绍 4. 基于socket来编写C/S架构的软件

网络=底层的物理连接介质+互联网协议(就是计算机界的英语) OSI七层 应用层(应用层\表示层\会话层):http,ftp 传输层:tcp/udp 网络层:ip 数据链路层:ethernet 物理层:发送电信号 1. 互联网协议,可看作是一个安装在计算机上的包 2. 交换机:有mac地址学习功能 3. ARP(地址解析协议),可将IP地址转成mac地址,mac地址转成IP地址 4. IP+端口可锁定一架计算机上的某个应用程序 5. IP 和子网掩码->局域网地址(子网地址) 6.  TCD又称好

网络基本原理,tcp三次握手,4次挥手,路由器,arp协议,网络7层模型

网络基本原理:局域网通信局域网是在同一个链路内相互通过mac地址通信的主机组成的集体比如在一个工作室内同一个路由器下面的几台电脑组成由于在最开始 电脑之间相互不知道对方在mac地址所以 电脑主机之间相互通信就需要通过广播的方式发给局域网内部的主机,这个时候因为主机一般都是链接的都是交换机,交换机的的内存内部有一个16K的空间的内存记录的是交换机的接口和主机的mac地址 ,不管哪个主机发广播的时候经过交换机的时候都要出示他的mac地址,这个时候主机的mac地址的就被mac地址和接口的方式记录在交换

TCP三次握手建立链接与四次挥手断开链接

防伪码:从基础开始,一步一个脚印 先简单介绍一下TCP协议. TCP(Transmission Control Protocol 传输控制协议)是一种面向连接的.可靠的.基于字节流的传输层协议.很复杂,但属于不论程序员还是运维人员都必会的基本功. 面向对象的--连接双方在通信前需要预先建立一条连接,这犹如实际生活中的打电话,电话必须拨通了以后才能交流. 可靠的--TCP协议中有诸多的规则来保障通信链路的可靠性,含应用数据分隔.重传机制.对首部和数据校验.对收到的数据进行排序,然后交给应用层.接收

转---tcp三次握手四次挥手syn fin......

http://blog.chinaunix.net/uid-22312037-id-3575121.html转自 一.TCP报文格式        TCP/IP协议的详细信息参看<TCP/IP协议详解>三卷本.下面是TCP报文格式图: 图1 TCP报文格式 上图中有几个字段需要重点介绍下:        (1)序号:Seq序号,占32位,用来标识从TCP源端向目的端发送的字节流,发起方发送数据时对此进行标记.        (2)确认序号:Ack序号,占32位,只有ACK标志位为1时,确认序号

TCP三次握手和四次断开

TCP,一个大家都熟悉的协议,对于技术人员来说,透彻的理解他,就到代表咱们的半只脚已经踏进了IT的大门. TCP的特点 TCP提供一种面向连接的.可靠的字节流服务.面向连接意味着是一对一的连接(通常是一个客户端连接一个服务端),在交换数据之前,需要先建立连接.在TCP的连接中,仅有一对一的双方建立连接,多播和广播不属于TCP的连接. TCP保证其可靠性的机制 应用数据被分割成TCP认为最适合发送的数据块.由TCP传递给IP的信息单位称为报文段或段(segment). 超时重传策略.当TCP发出一

TCP三次握手四次挥手过程梳理

1. 数据传输的大致示意图 1.1 TCP连接的几种状态说明 即命令 netstat 结果中的所有状态: 2. TCP连接建立的全过程 2.1 TCP三次握手建立TCP连接 1)客户端和服务端都处于CLOSED状态.(发起TCP请求的称为客户端,接受请求的称为服务端) 2)服务端打开服务端口,处于listen状态. 3)客户端发起连接请求.首先发送SYN(synchronous)报文给服务端,等待服务端给出ACK报文回应.发送的SYN=1,ACK=0,表示只发送了SYN信号.此时客户端处于SYN

HTTP从入门到入土(3)——TCP三次握手

TCP三次握手 客户端与服务器之间互相发送HTTP请求响应之前需要先进行TCP连接,因为HTTP是一个无连接.无状态协议,不存在连接的概念,只有请求和响应的概念.而请求和响应实际上只是数据包,他们需要传输通道进行传输,而这个传输通道就是TCP创建的通道.那么这个通道是如何创建的呢?就是通过TCP三次握手. 什么是TCP三次握手? TCP三次握手的流程如下所示: 从图中可以看出,三次握手分为三步: 1.客户端向服务端发送连接请求报文 2.服务端分配资源,并向客户端发送确认报文 3.客户端分配资源,