TCP三次握手详解和四次挥手

TCP的三次握手四次挥手时面试时面试官经常问道的问题

在互联网中,如何使不同网段的主机相互通信,需要用到TCP协议;
TCP,提供面向连接的服务,在传送数据之前必须先建立连接,数据传送完成后要释放连接。TCP是一种可靠的的运输服务,采用三次握手建立一个连接。

首先介绍下TCP的报文格式

序号 发送端为每个字节编号,方便接收端正确重组。
确认号 用于确认发送端的信息。
窗口大小 用于说明本地可接收数据段的数目。

标志位
URG 紧急指针位 1 开启 0 关闭。
不经过缓存直接提交给对方。

PSH 快速接受传递给应用层 1 开启 0 关闭
需要经过缓存,等一批报文段到齐,直接发送应用层。

SYN 同步序号位 建立连接的请求标记
FIN 断开连接的请求标记
ACK 确认序号位
RST 重新连接

三次握手

第一次握手
客户机想和服务器建立连接,就向服务器发送了一个SYN到服务器,等待服务器确认
第二次握手
TCP服务器收到请求报文后,先确认SYN包,如果同意连接,则发出SYN+ACK包.
第三次握手
客户端收到服务器的SYN+ACK包后,还需要向服务器发送确认包ACK,此包发送完毕,此后双方就可以开始通信了,完成三次握手。

四次挥手

由于TCP连接是全双工的,因此每个方向都必须单独进行关闭。这个原则是当一方完成它的数据发送任务后就能发送一个FIN来终止这个方向的连接。收到一个 FIN只意味着这一方向上没有数据流动,一个TCP连接在收到一个FIN后仍能发送数据。首先进行关闭的一方将执行主动关闭,而另一方执行被动关闭。
第一次挥手
服务器向客户端发送FIN和ACK位置1的TCP报文段。
第二次挥手
客户端向服务器返回ACK位置1的TCP报文段。
第三次挥手
客户端向服务器发送FIN和ACK的位置1的TCP报文段。
在TCP断开连接的过程中,有一个半关闭的概念。TCP的一方(通常是客户端)可以终止发送数据,但仍然可以接受数据,称为半关闭。

为什么建立连接时时三次握手,而断开连接时时四次挥手?
关闭连接时,服务器收到对方的FIN报文时,表示对方不再发送数据,但是还能接收数据,而自己也未必把全部数据都发送给对方了,所以发送完数据给对方后,再发送FIN报文给对方来表示同意现在关闭连接,因此,ACK和FIN一般都会分开发送,从而导致多了一次。

原文地址:https://blog.51cto.com/14449798/2427331

时间: 2024-11-28 23:23:43

TCP三次握手详解和四次挥手的相关文章

TCP三次握手详解及释放连接过程

TCP在传输之前会进行三次沟通,一般称为"三次握手",传完数据断开的时候要进行四次沟通,一般称为"四次挥手". 两个序号和三个标志位: (1)序号:seq序号,占32位,用来标识从TCP源端向目的端发送的字节流,发起方发送数据时对此进行标记.  (2)确认序号:ack序号,占32位,只有ACK标志位为1时,确认序号字段才有效,ack=seq+1.  (3)标志位:共6个,即URG.ACK.PSH.RST.SYN.FIN等,具体含义如下:  (A)URG:紧急指针(u

TCP三次握手详解(二)

四次挥手 以上过程流程图如下: 为什么断开连接需要四次握手?因为TCP链接是全双工的,即数据在两个方向上能同时传递,因此每个方向必须单独的进行关闭.这原则就是当一方完成它的数据发送任务后就能发送一个FIN来终止这个方向连接. 分析 TCP报文头中flags中的FIN被置为1,sequence number=418, acknowledgment number=203.返回一个确认报文,ack=seq+1=419,seq = ack=203.至此,source port23到dst port=54

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

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

TCP 三次握手建立连接,四次挥手断开连接,图解详细分析,有个疑点求帮忙解答????

继文章  http://blog.csdn.net/simonchi/article/details/41722511   之后,我觉得有必要来详细的说一下TCP的三次握手和四次挥手的过程,帮助大家理解这个过程. 首先来看一下tcpdump抓取的网络数据包,如何抓包分析参考 上面给出的链接 图中红色框选的是三次握手建立连接 第一次:客户端发送SYN报文,并设置seq=0, 第二次:服务端收到SYN报文,知道对方要求建立连接,发送SYN和ACK报文,并设置seq=0,ack=0(第一次的seq)+

TCP/IP三次握手详解

原文:http://www.cnblogs.com/CBDoctor/archive/2012/10/17/2727073.html 在TCP/IP协议中,TCP协议提供可靠的连接服务,采用三次握手建立一个连接. 第一次握手:建立连接时,客户端发送syn包(syn=j)到服务器,并进入SYN_SEND状态,等待服务器确认: 第二次握手:服务器收到syn包,必须确认客户的SYN(ack=j+1),同时自己也发送一个SYN包(syn=k),即SYN+ACK包,此时服务器进入SYN_RECV状态: 第

深入理解TCP协议:三次握手详解

1.什么是三次握手? TCP协议建立连接时,需要三次发送数据包: 第一次:客户机向服务器端请求建立连接 第二次:服务器收到客户机的请求,发出响应 第三次:客户机收到响应 认为连接建立成功 详细过程: 名词解释: SYN - 标志位 只有第一次和第二次为1,第三次和其他任何情况都是0 ACK - 标志位 只有第一次不为1,第二,三次和其他任何情况都是1 Sequence Number 顺序号,初始值为随机数 Acknowledgment Number 确认号,下一次对收到的数据顺序号的期望 第一次

Linux网络编程一、tcp三次握手,四次挥手

一.TCP报文格式 (图片来源网络) SYN:请求建立连接标志位 ACK:应答标志位 FIN:断开连接标志位 二.三次握手,数据传输,四次挥手 (流程图,图片来源于网络) (tcp状态转换图,图片来源于网络) 1.客户端向处于监听状态(LISTEN)的服务端发送请求连接的报文.此时,报文中SYN标志位为1(表明其为请求建立连接的报文),同时还会随机生成一个32位的随机序号(图中1000),请求连接的报文可以可以携带数据(图中(0)表明没有携带数据).客户端变为SYN_SENT状态. 2.服务器接

wireshark抓包图解-tcp三次握手四次挥手详解/

http://www.seanyxie.com/wireshark%E6%8A%93%E5%8C%85%E5%9B%BE%E8%A7%A3-tcp%E4%B8%89%E6%AC%A1%E6%8F%A1%E6%89%8B%E5%9B%9B%E6%AC%A1%E6%8C%A5%E6%89%8B%E8%AF%A6%E8%A7%A3/ wireshark抓包图解-tcp三次握手四次挥手详解/ tcpdump抓包命令使用方法及内容解析/

计算机网络——TCP三次、四次握手详解

三次握手:建立TCP连接 连接建立过程: B的TCP服务器进程先创建传输控制块TCB(存储了每一个连接中的一些重要信息,如:TCP连接表,到发送和接收缓存的指针,到重传队列的指针,当前的发送和接收序号,等),准备接受客户进程的连接请求.然后服务器进程就处于LISTEN(收听)状态,等待客户的连接请求.如有,即作出相应. A的TCP客户进程也是首先创建传输控制模块TCB,然后向B发出连接请求报文段,这时首部中的同步为SYN=1,同时选择一个初始序号seq=x.TCP规定,SYN报文段(即SYN=1