JavaEE: 深入探索TCP网络编程的奇妙世界(三)

news2024/11/14 18:35:26

文章目录

  • TCP核心机制
    • TCP核心机制三: 连接管理
      • 建立连接(三次握手)
      • 断开连接(四次挥手)
      • 三次握手/四次挥手 流程简图


TCP核心机制

书接上文~

TCP核心机制三: 连接管理

建立连接(三次握手),断开连接(四次挥手).
这里的次数指的是网络通信的次数,挥手/握手是形象的比喻(handshake,计算机中的常见术语)

网络中的握手,发送不携带业务数据(没有载荷,只有报头)的数据包,但是能起到"打招呼"的作用.

建立连接(三次握手)

在这里插入图片描述
要想搞懂三次握手,那就要知道三次握手要解决啥问题,为啥要三次握手,三次握手的意义何在?

答:

  1. 投石问路: 初步的验证通信的链路是否畅通.(这是进行可靠传输的"前提条件")

  2. 确认通信双方各自的发送能力和接收能力是否都正常
    举个例子:
    我和朋友连麦打游戏.
    在这里插入图片描述
    把麦克风看成发送能力,耳机看成接收能力,这就是确认的过程~

    为啥是三次握手?

    1. 四次是否可行?
      • 可行的,中间的一次,拆成两次,也可以.但是没必要这么做.
    2. 两次是否可行?
      • 不可行~
        这样就无法完成通信双方针对各自发送能力和接收能力的验证~

    针对TCP来说,必须是三次握手.
    其他协议,握手过程可不一定是三次~

  3. 让通信双方在进行通信之前,先对通信过程中需要用到的一些关键参数进行协商.
    TCP通信时,起始数据的序号,就是通过三次握手,来协商确定的~(换而言之,TCP序号,并不是从1开始的)
    每次建立连接,TCP的起始序号都不同(而且故意差别很大)

    这么约定的意义,在于避免出现"前朝的剑,斩本朝的官".
    具体解释一下~
    A和B建立连接了.
    在这里插入图片描述
    A和B传输业务数据.
    在这里插入图片描述

    在上面的过程中,可能有某个数据包"迷路"了,绕了一个大圈最终才到达对端~
    当他到达的时候,已经"改朝换代"了.

    针对这样的"迟到"的数据包,就需要把它丢弃掉,不能按照正常的流程来处理这里的数据了.

    A和B断开连接
    在这里插入图片描述
    过了一会,A和B又重新建立连接~
    在这里插入图片描述
    虽然还是 A B 两个主机的连接,但是可能是不同的应用程序.

    对于B来说,就需要区分当前收到的数据是"本朝"的还是"前朝"的.

    如何区分呢?
    答:给每个连接,都协商不同的起始的序号,如果发现收到的数据,和起始序号以及和最近收到的数据序号,都差别很大的话,那么就视为这个数据就是"前朝"的数据,把它丢掉.

小小的总结一下.
进行TCP三次握手的原因:

  1. 投石问路,验证通信路径上是否畅通.
  2. 验证通信双方的发送能力和接收能力是否正常.
  3. 协商重要的参数,比如TCP连接中的起始序号.
    在这里插入图片描述

断开连接(四次挥手)

四次挥手:(优雅地)断开连接.

前面谈到"超时重传"的时候,说到了"单方面释放连接".
而这里的四次挥手则是双方各自把对端的信息删除掉.

断开连接,不一定是"客户端主动",服务器也可以主动断开.

在这里插入图片描述
通信双方,各自给对方发送"FIN",各自给对方返回"ACK".

三次握手,之所以是三次,是因为中间两次的交互,合并在一起了.

对于四次挥手来说,中间两次,不一定能合并(大概率不能).

对于三次挥手来说,中间的两次,ACK+SYN,都是在系统内核中,由操作系统负责进行的,时机都是在收到SYN之后,就可以合并了.

对于四次挥手来说.
ACK是内核控制的,但是FIN的触发,则是通过应用程序,调用close/进程退出,来触发的.

代码中针对socket.close() => 系统内部,就是发送FIN.
在这里插入图片描述

三次握手/四次挥手 流程简图

在这里插入图片描述
在这里插入图片描述
通过看图,我们可以看到:

  1. TCP是有状态的.
  2. TCP的状态转换.

这些东西很复杂,我们只要能够认识这里面的几个关键状态就可以了.

  • LISTEN
    服务器进入的状态
    服务器把端口绑定好,相当于进入了listen状态了.
    此时服务器就已经初始化完毕,准备好随时迎接客户端了.

    类似于手机开机,信号良好,随时可以有人来打电话了.

  • ESTABLISHED
    客户端和服务器都会进入的状态.
    表示TCP连接建立完成(保存了对方的信息了)
    接下来就可以进行业务数据的通信了.

    类似于电话接通,可以说话了.

  • CLOSE_WAIT
    被动断开连接的一方,会进入这个状态.
    先收到FIN的一方,“等待代码执行close方法”

    如果发现,服务器这端,存在在大量的CLOSE_WAIT状态的TCP连接,说明什么?
    此时说明服务器代码可能有bug.
    排查close是否写了,以及是否及时执行到了.

  • TIME_WAIT
    主动断开连接的一方,会进入这个状态.
    此处的TIME_WAIT按照时间来等待,达到一定时间之后,连接也就释放了.

    为啥不直接释放,而是要等待一定时间呢?
    就是为了防一手最后的ACK丢包~
    在这里插入图片描述

    TIME_WAIT存在的时间,称为MSL(MSL => 数据报在网络传输中消耗的最大时间)
    MSL在不同的系统不一样,都是可配置的.
    比如Linux默认的值为60s.正常来说,网络数据,是不会消耗这么久的时间的.

最后再给一张TCP状态转换的一个汇总(简单了解一下就行):
在这里插入图片描述

本文到这里就结束啦~

在这里插入图片描述

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

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

相关文章

PM2.5粉尘传感器详解(STM32)

目录 一、介绍 二、传感器原理 1.原理图 2.引脚描述 3.工作原理介绍 4.粉尘浓度转化关系 5.空气污染指数 三、程序设计 main.c文件 PM25.h文件 PM25.c文件 四、实验效果 五、资料获取 项目分享 一、介绍 GP2Y1014AU是日本夏普公司开发的一款光学灰尘浓度检测传…

探索 Web Speech API:实现浏览器语音识别与合成

引言 Web Speech API 是一项由 W3C 开发的 Web 标准,为开发者提供了在 Web 应用程序中实现语音识别和语音合成的能力。通过 Web Speech API,我们可以让网页与用户进行语音交互,实现更加智能化和便捷的用户体验。本文将深入探讨 Web Speech A…

14 vue3之内置组件trastion全系列

前置知识 Vue 提供了 transition 的封装组件,在下列情形中,可以给任何元素和组件添加进入/离开过渡: 条件渲染 (使用 v-if)条件展示 (使用 v-show)动态组件组件根节点 自定义 transition 过度效果,你需要对transition组件的name属性自定义。…

【Linux】当前进展

驱动层日志添加了下文件目录,函数,代码行的打印(这里要小心,驱动目录源代码打印日志里边添进程号可能有问题,因为在驱动初始化的时候,内核还没有创建进程,不过猜测可以先不打印进程相关信息&…

python使用vscode 所需插件

1、导读 环境:Windows 11、python 3.12.3、Django 4.2.11、 APScheduler 3.10.4 背景:换系统需要重新安装,避免后期忘记,此处记录一下啊 事件:20240921 说明:记录,方便后期自己查找 2、插件…

Ansys Zemax | 如何使用琼斯矩阵表面

附件下载 联系工作人员获取附件 概览 琼斯矩阵 (Jones Matrix) 表面是一种非常简便的定义偏振元件的方法。这篇文章通过几个示例介绍了如何使用琼斯矩阵。 介绍 光线追迹程序一般只考虑光线的几何属性(位置、方向和相位)。光线传播到一个表面时的全…

SQL - 进阶语法(二)约束

1. SQL约束 约束用于约束表中的数据规则,如若存在违反行为,行为会被约束终止。 • NOT NULL 确保列不能有NULL值 如果添加一行新的数据,不能有null值,否则无法添加 新建表格 CREATE TABLE new_table( ID int NOT NULL, NAME …

梯形区域分解实现避障路径规划全覆盖路径规划

系列文章目录 提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加 TODO:写完再整理 文章目录 系列文章目录前言(1)功能(2)算法(3)参考链接(4)…

【服务器第二期】mobaxterm软件下载及连接

【服务器第二期】mobaxterm软件下载及连接 前言什么是SSH什么是FTP/SFTP mobaxterm软件介绍mobaxterm软件下载SSH登录使用方法1-新建ssh连接方法2-打开已有的ssh连接方法3-通过ssh命令建立连接 SFTP数据传输方法1-建立ssh连接后直接拖拽方法2-建立sftp连接再拖拽方法3-直接使用…

Nacos配置管理(2)-----配置热更新

有很多的业务相关参数,将来可能会根据实际情况临时调整。例如购物车业务,购物车数量有一个上限,默认是10,对应代码如下: 现在这里购物车是写死的固定值,我们应该将其配置在配置文件中,方便后期…

while(cin>>a)

while(cin>>a)要结束输入CTRLZ换行 输入先调用: istream& operator>> (istream& is, string& str); 但返回值类型时istream, 再调用: 重载的原为(bool)istream,返回值为bool,重载的为括号&#xff0c…

若依前后端分离版项目电子证书查询系统部署到Linux生产环境

项目背景:这个项目之前是PHP语言开发的,采用MVC混编的,前端用Layui框架后端用ThinkPHP8.0框架。客户要求给改成Java语言的,就选用了若依前后端分离低代码版。本地开发调试没有问题,就记录下整个项目上线过程。 服务器背…

How can I stream a response from LangChain‘s OpenAI using Flask API?

题意:怎样在 Flask API 中使用 LangChain 的 OpenAI 模型流式传输响应 问题背景: I am using Python Flask app for chat over data. In the console I am getting streamable response directly from the OpenAI since I can enable streming with a f…

Go语言基础学习02-命令源码文件;库源码文件;类型推断;变量重声明

命令源码文件 GOPATH指向的一个或者多个工作区,每个工作区都会有以代码包为基本组织形式的源码文件。 Go语言中源码文件可以分为三类:命令源码文件、库源码文件、测试源码文件。 命令源码文件: 命令源码文件是程序的运行入口,是每…

k8s技术

---------------第一部分---------------------- 一.应用部署方式 1.传统部署:直接部署在物理机上,简单但是耗资 2.虚拟化部署:一台物理机上面有多个虚拟机,提供了虚拟机间一定的安全,但是增加了操作系统,…

【C++】STL----deque

🔥个人主页🔥:孤寂大仙V 🌈收录专栏🌈:C从小白到高手 🌹往期回顾🌹:【C】STL----stack和queue常见用法 🔖 流水不争,争的是滔滔不息。 文章目录 一…

某花顺爬虫逆向分析

目标网站: aHR0cHM6Ly9xLjEwanFrYS5jb20uY24v 一、抓包分析 携带了cookie,每次请求的cookie都不一样,且不携带cookie不能成功返回数据 hook Cookie代码 _cookie document.cookie Object.defineProperty(document, cookie, {get(){con…

前端框架的选择和对比

前端框架的选择取决于项目的具体需求、团队的技术栈以及长期的技术规划。以下是几个主流前端框架的对比和选择建议: 1. React 特点: 由Facebook开发,基于组件化的设计思想,使用JSX语法,数据流单向,生态系统丰富。适用…

Navicate 链接Oracle 提示 Oracle Library is not loaded ,账号密码都正确地址端口也对

Navicate 链接Oracle 提示 Oracle Library is not loaded ,账号密码都正确地址端口也对的问题 解决办法 出现 Oracle Library is not loaded 错误提示,通常是因为 Navicat 无法找到或加载 Oracle 客户端库(OCI.dll)。要解决这个问题&#x…

解释器模式:将语法规则与执行逻辑解耦

解释器模式(Interpreter Pattern)是一种行为设计模式,它提供了评估语言的语法或表达式的方式。该模式通过定义一个语言的文法表示,并通过解释这些表示来执行相应的操作。 解释器模式主要用于设计一种特定类型的计算机语言或表达式…