网络原理TCP之“三次握手“

TCP内核中的建立连接

众所周知,TCP是有连接的.

当我们在客户端敲出socket =new  Socket(serverIp,severPort)时,就在系统内核就在建立连接

真正建立连接是在系统内核中建立的,我们程序员只是调用相关的api.

在此处,我们把TCP的建立连接称为三次握手.

系统在内核建立连接时如上图所示,总共有四次交互,但是在实际过程中,其中的两次交互能够合二为一,所以我们称作"三次握手"

这个所谓的建立连接的过程,本质上就是通信双方各自给对方发起一个syn,各自给对方回应一个ack.

(这里客户端的信息告知服务器 这个操作确实在第一次握手的时候就完成了,但是最终确立这个连接要建立,确立出,后续要进行通信,得把所有的流程都走完)

虽然第一次"握手",客户端已经把自己的信息告诉服务器了,但是服务器具体是否要确定存储这个信息,还得再看看.

等到所有的"握手"环节都完成后,服务器才会最终保存客户端的相关信息.

首先,我们客户端作为发起通信的一方,应该首先发起syn(同步报文段),

此处的syn是一个特殊的TCP数据报.

1.没有载荷.不会携带应用层数据.

2.六个标志位中的第五位,为1.

虽然syn不会带有应用层载荷,但是也会带有IP报头/以太网数据帧帧头...更会有TCP报头

TCP包头就包含了客户端自己的端口.IP报头中就包含了客户端自己的IP.(这个过程,也是客户端在告诉服务器,我是谁)

这里当客户端第一次给服务器发起syn(同步报文)时,有两种可能性

1.服务器同意了,服务器表示我也愿意和你建立连接

2.服务器没同意.(一般来说这种情况比较少见,就是服务器负载极高的情况下,服务器完全无法响应,客户端太多了,直接就没下文了)

服务器收到syn之后,会返回ack(确认应答),意思就是收到了

接下来服务器还会再返回syn,代表我接收你的连接(我也愿意和你建立连接)

这里的syn指的是synchronized,同步,就是使其进入连接状态.客户端服务器就得相互配合好一系列工作.

syn这样的数据包,不携带载荷,没有应用层数据,也就不代表任何应用程序的业务逻辑,syn起到的作用就只是"打招呼",因此我们就把这个动作称为"握手".

简略版的三次握手

详细版三次"握手"

三次"握手的意义"

1.三次握手,可以针对通信路径,进行投石问路,初步的确认一下通信链路是否畅通.(可靠性的前提条件)(关注点在中间过程)

2.三次握手,也是在验证通信双方,发送能力和接收能力是否正常.(关注点在两端)

(1)客户端首先发送一个syn报文,服务器就会知道客户端的数据发送能力和服务器的数据接收能力是正常的,但是此时客户端并不知道.

(2)服务器给客户端返回syn+ack报文,客户端就会知道自己的数据接收和服务器的数据发送功能是正常的,也包括客户端的数据发送和服务器的数据接收功能,但是服务器此时并不知道

(3)客户端给服务器返回ack报文,此时,服务器就知道了自己的数据发送和客户端的数据接收功能是正常的,当然也包括客户端的数据发送和服务器的数据接收功能是正常的.

3.三次握手的过程中也会协商一些必要的參数

 通信是客户端服务器两方的事情.要配合.其中的有些内容要保持一致.

TCP中也是有很多參数要进行协商的.往往是以"选项"部分来体现的.

最少0字节

最多40字节

其中有一个关键的信息,TCP通信的序号,起始值.

TCP一次通信过程中,序号不是从0或者从1开始计算的.

而是选择一个比较大的数字,以这个数字开头来计算的

即使是同一个客户端和服务器,每次连接,开始的序号都会不同,(这样设计主要是为了避免"前朝的剑,斩本朝的官").

第一次连接的过程中,传输的有一个数据包,还没有发送成功,还在数字链路里面进行等待,迟迟没有到达对端.等待终于到了对端的实收,已经是另外一个客户端,另外一次连接了,之前的连接早没了,现在是新的连接了!!

此时,这份数据应该被丢弃!!数据报按照ip+端口进行识别.第一个连接,是用客户端A来连的.第二个连接是用客户端B来连的.(恰好是同一个端口的话,客户端概率是比较低的,服务器概率很大)

 此时数据到达这一边,早已不是之前的客户端了,再把这个数据进行发送,就不合适了,

此时,应该丢弃这个数据包

在这种情况下,如何识别出数据是之前的数据包??

就是通过序号识别出来的!!

(序号是不同的,也不是随机的,背后还有一系列分配策略)

正常数据包的序号都是从开始序号往后依次排的.就算偶尔丢包,偶尔数据部连续,差异也不会很大.

"前朝"的数据包的序号和本朝的数据包的序号差异是非常大的,很容易一眼识别出来

断开连接(四次挥手)

连接,本质上就是让通信双方保存对方的信息!!

每个客户端/服务器,都要保存很多的对端信息.

一旦多了,就要使用"数据结构".

断开连接的本质目的,就是为了把对端的信息,从数据结构中删除掉/释放掉.

有了"逻辑删除之后",此时就相当于断开连接了.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/700981.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQL-FEFT JOIN (拼接表)

语法 SELECT column_name(s) FROM table1 LEFT JOIN table2 ON table1.column_nametable2.column_name; 按照一定规则,将表table1和表table2拼接起来。 例: Employees 表: ------------------------ | Column Name | Type | ------…

QoS 服务质量

服务质量 QoS (Quality of Service) 服务质量可用若干基本性能指标来描述,包括:可用性、差错率、响应时间、吞吐量、分组丢失率、连接建立时间、故障检测和改正时间等。 服务提供者可向其用户保证某一种等级的服务质量。 服务性能的总效果,…

【接口加密】接口加密的未来发展与应用场景

目录 3.1 接口加密与区块链技术的结合 3.1.1 区块链技术的安全特性与优势 3.1.2 接口加密在区块链中的应用案例 3.2 接口加密与物联网安全 3.2.1 物联网安全的挑战与需求 3.2.2 接口加密在物联网领域的实际应用 3.3 接口加密在金融与电子商务领域的应用 随着信息技术的不…

【Java网络编程06】HTTPS原理

1. HTTPS基本概念 HTTPS:HTTPS也是一个应用层协议,它在HTTP协议的基础上引入了一个加密层——SSL协议,区别就在于HTTP协议是基于明文传输的(不安全),使用HTTPS加密就能在一定程度上防止数据在传输过程中被…

redis架构系列——生产常用的部署模式介绍

主从高可用模式 这是最基本的高可用模式,它允许数据从主节点自动复制到一个或多个从节点。这种模式下,从节点可以处理读操作,从而实现负载均衡,并提供故障恢复的基本功能。然而,它的故障恢复不能自动化,写操…

内核解读之内存管理(8)什么是page cache

文章目录 0. 文件系统的层次结构1.什么是page cache2.感观认识page cache3. Page Cache的优缺点3.1 Page Cache 的优势3.2 Page Cache 的劣势 0. 文件系统的层次结构 在了解page cache之前,我们先看下文件系统的层次结构。 1 VFS 层 VFS ( Virtual Fi…

Vulhub 靶场训练 DC-8解析

一、环境搭建 kali的IP地址:192.168.200.14 DC-8的IP地址:192.168.200.13(一个flag) 靶机和攻击机处于同一个网络方式:nat或桥接 若出现开机错误,适当将dc的兼容版本改低,我的vmware workst…

Vue事件处理之v-on

1. 使用及定义 定义方法 function 方法名称(接受的event或是什么都不写) {//不管方法后括号内写与不写event,都可以接受到方法内表达式 }//定义一个接受参数的方法,此时也会在传入event function 方法名称(传入参数) {//可接受传入参数与event方法内表达式 } //定义一个接受参…

说一下 JVM 有哪些垃圾回收器?

如果说垃圾收集算法是内存回收的方法论,那么垃圾收集器就是内存回收的具体实现。下图展示了7种作用于不同分代的收集器,其中用于回收新生代的收集器包括Serial、ParNew、Parallel Scavenge,回收老年代的收集器包括SerialOld、Parallel Old、C…

恒创科技:香港服务器和香港云服务器哪个好啊?

"香港服务器"和"香港云服务器",是两种不同的香港区域的服务器,免备案,都有各自的优势和适用场景,取决于您的需求和预算。以下是它们的一些区别和特点: 香港服务器: 物理服务器&#xf…

第2.5章 StarRocks表设计——行列混存表

注:本篇文章阐述的是StarRocks- 3.2.3版本的行列混存表 一、概述 1.1 背景 StarRocks 基于列存格式引擎构建,在高并发场景,用户希望从系统中获取整行数据。当表宽时,列存格式将放大随机IO和读写。自3.2.3开始,StarRo…

密码算法简单整理

密码组成 国外的密码算法: DES、3DES、AES、SHA1、SHA2、SHA3、DSA、RSA、RC4等 高危密码算法: MD5、DES、RSA1024以下、SSH1.0、SSL3.0以下、SHA1等 密码算法通常可分为三大类: 对称密码算法 非对称密码算法 密码杂凑算法 1.对称密码算法&am…

LeetCode 1637.两点之间不包含任何点的最宽垂直区域

给你 n 个二维平面上的点 points ,其中 points[i] [xi, yi] ,请你返回两点之间内部不包含任何点的 最宽垂直区域 的宽度。 垂直区域 的定义是固定宽度,而 y 轴上无限延伸的一块区域(也就是高度为无穷大)。 最宽垂直区…

udp服务器【Linux网络编程】

目录 一、UDP服务器 1、创建套接字 2、绑定套接字 3、运行 1)读取数据 2)发送数据 二、UDP客户端 创建套接字: 客户端不用手动bind 收发数据 处理消息和网络通信解耦 三、应用场景 1、服务端执行命令 2、Windows上的客户端 3…

2278. 企鹅游行(最大流,拆点)

活动 - AcWing 在南极附近的某个地方,一些企鹅正站在一些浮冰上。 作为群居动物,企鹅们喜欢聚在一起,因此,它们想在同一块浮冰上会合。 企鹅们不想淋湿自己,所以它们只能利用自己有限的跳跃能力,在一块块…

UnityWebGL 设置全屏

这是Unity导出Web默认打开的页面尺寸 修改后效果 修改 index.html 文件 1.div元素的id属性值为"unity-container",宽度和高度都设置为100%,意味着该div元素将占据整个父容器的空间。canvas元素的id属性值为"unity-canvas"&#xff…

论文阅读——SimpleClick

SimpleClick: Interactive Image Segmentation with Simple Vision Transformers 模型直接在VIT上增加交互是分割 用VIT MAE方法训练的预训练权重 用交互式分割方法微调,微调流程: 1、在当前分割自动模拟点击,没有人为提供的点击 受到RITM启发…

uni-app nvue vue3 setup中实现加载webview,解决nvue中获取不到webview实例的问题

注意下面的方法只能在app端使用, let wv plus.webview.create("","custom-webview",{plusrequire:"none", uni-app: none, width: 300,height:400,top:uni.getSystemInfoSync().statusBarHeight44 }) wv.loadURL("https://ww…

使用PM2实现高效的应用监控与管理

微信搜索“好朋友乐平”关注公众号。 1. pm2 PM2 是一个流行的进程管理器,用于 Node.js 应用程序。它支持应用程序的负载均衡、自动重启、日志管理、监控以及多环境管理等功能。PM2让开发者能够以守护进程的方式运行和管理 Node.js 应用,即使在应用崩溃…

基于springboot+vue的精准扶贫管理系统(前后端分离)

博主主页:猫头鹰源码 博主简介:Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战,欢迎高校老师\讲师\同行交流合作 ​主要内容:毕业设计(Javaweb项目|小程序|Pyt…