网络:TCP协议三次握手与四次挥手

简介: 网络:TCP协议三次握手与四次挥手

一、理解TCP报文

TCP报文格式_TCP报文包含哪些内容:

TCP报头中的源端口号和目的端口号同IP数据报中的源IP与目的IP唯一确定一条TCP连接。

TCP在发送数据前必须在彼此间建立连接,这里连接意思是:双方需要内保存对方信息(例如:IP,Port…)

报文主要字段的解释
Sequence number  序号 表示发送的数据字节流,确保TCP传输有序,对每个字节编号。
初始序号是随机的。
Acknowledge number 确认序号 发送方期待接收的下一序列号,接收成功后的数据字节序列号加 1。
只有ACK=1时才有效。
acknowledgement ACK 确认序号的标志
ACK=1表示确认号有效
ACK=0表示报文不含确认序号信息
synchronous SYN 连接请求序号标志,用于建立连接
SYN=1表示请求连接
finish FIN 结束标志,用于释放连接,为1表示关闭本方数据流
push PSH 传送
reset RST 重置
urgent URG 紧急
LISTEN 等待从任何远端TCP 和端口的连接请求。
FIN_WAIT_1 等待远端TCP 的连接终止请求,或者等待之前发送的连接终止请求的确认。
FIN_WAIT_2

等待远端TCP 的连接终止请求。

CLOSE_WAIT 等待本地用户的连接终止请求
CLOSING 等待远端TCP 的连接终止请求确认
LAST_ACK 等待先前发送给远端TCP 的连接终止请求的确认(包括它字节的连接终止请求的确认)
TIME_WAIT 等待足够的时间过去以确保远端TCP 接收到它的连接终止请求的确认。
CLOSED 不再连接状态。

二、TCP三次握手过程分析

三次握手 客户端 发送信息 服务端
第一次握手

客户端发送请求信息给服务器

1、客户端即不知道自己发送与接收的能力是否正常

2、客户端也不知道服务器发送与接收的能力是否正常

SYN=1
seq=x

服务器接收到客户端发来的信息

1、服务器知道客户端发送正常,不知道客户端接收的能力是否正常

2、服务器知道自己接收正常,不知道自己发送的能力是否正常。

第二次握手

客户端收到服务端发来的信息

1、客户端知道自己发送、接收正常

2、客户端知道服务端接收、发送正常

客户端全部知道

ACK=1
ack=x+1
SYN=1
seq=y
服务器发送信息给客户端
第三次握手 客户端发给服务器 seq=x+1
ACK=1
ack=y+1

服务器接收到客户端发来的信息

1、服务端知道客户端发送,接收正常

2、服务端知道自己发送、接收也正常

服务端全部知道

上面分析过程可以看出,握手两次达不到让双方都知道自己、对方的接收、发送能力都正常的结论的。
由此我们知道三次握手的目的是让--客户端、服务端 都知道自己和对方 接收和发送的能力正常。
所以三次握手不能少,多了浪费网络资源。

三、TCP四次挥手分析

四次挥手 客户端 发送信息 服务端
第一次挥手 客户端发送请求
FIN-WAIT-1状态
1
FIN=1
seq=u

第二次挥手 ACK=1
ack=u+1
seq=v
服务端收到请求
服务端发送请求
CLOSE-WAIT状态
2
第三次挥手 客户端收到服务器确认结果后进入FIN-WAIT-2状态
客户端发送
3
FIN=1
ACK=1
ack=u+1
seq=w
服务端发送信息
LAST-ACK状态
4
第四次挥手 客户端收到回复
客户端发送
TIME-WAIT状态
客户端经过2个最长报文段寿命后,客户端CLOSE
5
ACK=1
ack=w+1
seq=u+1
服务端确认
服务端立刻进入CLOSE状态
6
四次挥手需要考虑服务端是否有正在发送的数据
所以客户端发起结束请求,服务端不能立即响应结束。
简单理解:
客户端发起结束请求
服务端收到请求,同时告诉客户端自己收到请求
服务端确认没有正在发送的数据,告诉客户端
客户端收到服务端的确认后结束,服务端结束

第一次挥手:客户端发出释放FIN=1,自己序列号seq=u,进入FIN-WAIT-1状态

第二次挥手:服务器收到客户端的后,发出ACK=1确认标志和客户端的确认号ack=u+1,自己的序列号seq=v,进入CLOSE-WAIT状态

第三次挥手:客户端收到服务器确认结果后,进入FIN-WAIT-2状态。此时服务器发送释放FIN=1信号,确认标志ACK=1,确认序号ack=u+1,自己序号seq=w,服务器进入LAST-ACK(最后确认态)

第四次挥手:客户端收到回复后,发送确认ACK=1,ack=w+1,自己的seq=u+1,客户端进入TIME-WAIT(时间等待)。客户端经过2个最长报文段寿命后,客户端CLOSE;服务器收到确认后,立刻进入CLOSE状态。

四、正是因为TCP协议三次握手、四次挥手所以TCP是安全连接,区别与UDP协议。

五、HTTP与TCP的关系

TCP是传输层协议,而HTTP是应用层协议。

HTTP基于TCP连接基础上,所以三次握手有人说是HTTP的有人说是TCP的,准确是TCP。

TCP就是单纯建立连接,不涉及任何我们需要请求的实际数据,简单的传输。

HTTP是用来收发数据的。

六、欢迎交流指正,关注我,一起学习。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
1月前
|
负载均衡 网络协议 算法
|
7天前
|
负载均衡 网络协议 算法
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
这网络层就像搭积木一样,上层协议都是基于下层协议搭出来的。不管是ping(用了ICMP协议)还是tcp本质上都是基于网络层IP协议的数据包,而到了物理层,都是二进制01串,都走网卡发出去了。 如果网络环境没发生变化,目的地又一样,那按道理说他们走的网络路径应该是一样的,什么情况下会不同呢? 我们就从路由这个话题聊起吧。
29 4
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
|
3天前
|
网络协议
TCP报文格式全解析:网络小白变高手的必读指南
本文深入解析TCP报文格式,涵盖源端口、目的端口、序号、确认序号、首部长度、标志字段、窗口大小、检验和、紧急指针及选项字段。每个字段的作用和意义详尽说明,帮助理解TCP协议如何确保可靠的数据传输,是互联网通信的基石。通过学习这些内容,读者可以更好地掌握TCP的工作原理及其在网络中的应用。
|
3天前
|
网络协议 安全 网络安全
探索网络模型与协议:从OSI到HTTPs的原理解析
OSI七层网络模型和TCP/IP四层模型是理解和设计计算机网络的框架。OSI模型包括物理层、数据链路层、网络层、传输层、会话层、表示层和应用层,而TCP/IP模型则简化为链路层、网络层、传输层和 HTTPS协议基于HTTP并通过TLS/SSL加密数据,确保安全传输。其连接过程涉及TCP三次握手、SSL证书验证、对称密钥交换等步骤,以保障通信的安全性和完整性。数字信封技术使用非对称加密和数字证书确保数据的机密性和身份认证。 浏览器通过Https访问网站的过程包括输入网址、DNS解析、建立TCP连接、发送HTTPS请求、接收响应、验证证书和解析网页内容等步骤,确保用户与服务器之间的安全通信。
26 1
|
29天前
|
安全 搜索推荐 网络安全
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
55 11
|
1天前
|
前端开发 网络协议 安全
【网络原理】——HTTP协议、fiddler抓包
HTTP超文本传输,HTML,fiddler抓包,URL,urlencode,HTTP首行方法,GET方法,POST方法
|
28天前
|
监控 网络协议 网络性能优化
网络通信的核心选择:TCP与UDP协议深度解析
在网络通信领域,TCP(传输控制协议)和UDP(用户数据报协议)是两种基础且截然不同的传输层协议。它们各自的特点和适用场景对于网络工程师和开发者来说至关重要。本文将深入探讨TCP和UDP的核心区别,并分析它们在实际应用中的选择依据。
56 3
|
1月前
|
网络协议 网络安全 网络虚拟化
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算。通过这些术语的详细解释,帮助读者更好地理解和应用网络技术,应对数字化时代的挑战和机遇。
106 3
|
1月前
|
网络虚拟化
生成树协议(STP)及其演进版本RSTP和MSTP,旨在解决网络中的环路问题,提高网络的可靠性和稳定性
生成树协议(STP)及其演进版本RSTP和MSTP,旨在解决网络中的环路问题,提高网络的可靠性和稳定性。本文介绍了这三种协议的原理、特点及区别,并提供了思科和华为设备的命令示例,帮助读者更好地理解和应用这些协议。
69 4
|
10天前
|
SQL 安全 网络安全
网络安全与信息安全:知识分享####
【10月更文挑战第21天】 随着数字化时代的快速发展,网络安全和信息安全已成为个人和企业不可忽视的关键问题。本文将探讨网络安全漏洞、加密技术以及安全意识的重要性,并提供一些实用的建议,帮助读者提高自身的网络安全防护能力。 ####
47 17