计算机网络学习27:TCP连接与连接释放

简介: 客户端和服务端都是先建立传输控制模块

三次握手


客户端和服务端都是先建立传输控制模块。


SYN=1,表明这是一个TCP连接请求报文段。序号字段seq被设置了一个初始值x,作为TCP客户进程所选择的初始序号。


TCP规定SYN被设置为1的报文段不能携带数据,但要消耗掉一个序号。


由于是TCP客户端主动发起的,因此称为主动打开链接。TCP服务进程是被动打开(监听)


TCP服务端发送的报文中的SYN=1,ACK=1表明这是一个 连接请求确认报文段。seq序号字段作为服务器选择的初始序号,确认号ack为x+1,这是对tcp 客户进程选择的初始序号 的确认。同时这个报文段也不能设置数据,因为这个是SYN被设置为1的报文段。同样也消耗掉一个序号。


这个时候客户端返回的 ACK=1, seq=x+1, ack=y+1,这是因为TCP客户进程发送的第一个TCP报文段的序号为x,并且不携带数据。请注意:TCP规定普通的TCP报文段可以携带数据,如果不携带数据,则不消耗序号。


在这种情况下,所发送的下一个数据报文段的序号仍是seq=x+1。确认号ack=y+1就是对服务器的确认。

TCP客户进程为什么最后还要发送给一个普通的TCP确认报文段呢?换句话说,就是两次握手能否建立连接?

如果改为 两次握手:

这将白白浪费服务器的资源。

四次挥手

客户端发送的报文段首部中的终止位 FIN =1,确认为ACK=1,表明这是一个TCP连接释放报文段。


同时也对之前收到的报文段进行确认:序号seq=u,它等于客户进程发送的最后一个数据的最后字节序号+1,。


ack=v,等于TCP客户进程最后一个进程收到的服务器的seq+1;


TCP规定:终止位FIN=1的报文段即使不携带数据,也要消耗掉一个序号。

30e8da831b334634977deb81c49b813b_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

服务器发的:ACK=1,表明是一个普通的 TCP确认报文段。


序号seq字段的值为v,等于服务器进程之前已传送过的数据的最后一个字节的序号+1;


ack就是对上次的seq=u进行确认+1;同时服务进程通知高层应用进程:客户进程要断开与自己的连接。


此时TCP客户进程到TCP服务进程这个方向的连接就释放了。

这是TCP连接属于半关闭状态。也就是服务器进程到客户进程这个方向的连接没有关闭。

这个状态可能会持续一段时间。等待TCP服务进程发送的释放报文段。

然后TCP高层应用进程就通知 服务进程进行被动释放(没有数据要传输了)。

在TCP客户进程发送的 第二次TCP普通确认中 seq=u+1 是因为 之前发送的TCP连接释放报文段虽然不携带数据,但要消耗掉一个序号。ack就是对之前seq=w的确认了。

MSL:最长报文段寿命。

b96ab5e31951d2709dbf64cdd8d68dc8_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
2天前
|
负载均衡 网络协议 算法
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
这网络层就像搭积木一样,上层协议都是基于下层协议搭出来的。不管是ping(用了ICMP协议)还是tcp本质上都是基于网络层IP协议的数据包,而到了物理层,都是二进制01串,都走网卡发出去了。 如果网络环境没发生变化,目的地又一样,那按道理说他们走的网络路径应该是一样的,什么情况下会不同呢? 我们就从路由这个话题聊起吧。
18 4
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
|
24天前
|
监控 网络协议 网络性能优化
网络通信的核心选择:TCP与UDP协议深度解析
在网络通信领域,TCP(传输控制协议)和UDP(用户数据报协议)是两种基础且截然不同的传输层协议。它们各自的特点和适用场景对于网络工程师和开发者来说至关重要。本文将深入探讨TCP和UDP的核心区别,并分析它们在实际应用中的选择依据。
52 3
|
1月前
|
网络协议 算法 网络性能优化
计算机网络常见面试题(一):TCP/IP五层模型、TCP三次握手、四次挥手,TCP传输可靠性保障、ARQ协议
计算机网络常见面试题(一):TCP/IP五层模型、应用层常见的协议、TCP与UDP的区别,TCP三次握手、四次挥手,TCP传输可靠性保障、ARQ协议、ARP协议
|
1月前
|
编解码 安全 Linux
网络空间安全之一个WH的超前沿全栈技术深入学习之路(10-2):保姆级别教会你如何搭建白帽黑客渗透测试系统环境Kali——Liinux-Debian:就怕你学成黑客啦!)作者——LJS
保姆级别教会你如何搭建白帽黑客渗透测试系统环境Kali以及常见的报错及对应解决方案、常用Kali功能简便化以及详解如何具体实现
|
1月前
|
物联网 5G 数据中心
|
1月前
|
安全 网络协议 算法
网络空间安全之一个WH的超前沿全栈技术深入学习之路(8-1):主动信息收集之ping、Nmap 就怕你学成黑客啦!
网络空间安全之一个WH的超前沿全栈技术深入学习之路(8-1):主动信息收集之ping、Nmap 就怕你学成黑客啦!
|
1月前
|
网络协议 安全 NoSQL
网络空间安全之一个WH的超前沿全栈技术深入学习之路(8-2):scapy 定制 ARP 协议 、使用 nmap 进行僵尸扫描-实战演练、就怕你学成黑客啦!
scapy 定制 ARP 协议 、使用 nmap 进行僵尸扫描-实战演练等具体操作详解步骤;精典图示举例说明、注意点及常见报错问题所对应的解决方法IKUN和I原们你这要是学不会我直接退出江湖;好吧!!!
网络空间安全之一个WH的超前沿全栈技术深入学习之路(8-2):scapy 定制 ARP 协议 、使用 nmap 进行僵尸扫描-实战演练、就怕你学成黑客啦!
|
1月前
|
网络协议 安全 算法
网络空间安全之一个WH的超前沿全栈技术深入学习之路(9):WireShark 简介和抓包原理及实战过程一条龙全线分析——就怕你学成黑客啦!
实战:WireShark 抓包及快速定位数据包技巧、使用 WireShark 对常用协议抓包并分析原理 、WireShark 抓包解决服务器被黑上不了网等具体操作详解步骤;精典图示举例说明、注意点及常见报错问题所对应的解决方法IKUN和I原们你这要是学不会我直接退出江湖;好吧!!!
网络空间安全之一个WH的超前沿全栈技术深入学习之路(9):WireShark 简介和抓包原理及实战过程一条龙全线分析——就怕你学成黑客啦!
|
1月前
|
人工智能 安全 Linux
网络空间安全之一个WH的超前沿全栈技术深入学习之路(4-2):渗透测试行业术语扫盲完结:就怕你学成黑客啦!)作者——LJS
网络空间安全之一个WH的超前沿全栈技术深入学习之路(4-2):渗透测试行业术语扫盲完结:就怕你学成黑客啦!)作者——LJS
下一篇
DataWorks