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

文章目录

  • 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.xdnf.cn/news/1542084.html

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

相关文章

基于SpringBoot+Vue的智慧物业管理系统

作者:计算机学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等,“文末源码”。 专栏推荐:前后端分离项目源码、SpringBoot项目源码、SSM项目源码 精品专栏:Java精选实战项目源码、Python精…

SpringBoot3核心特性-核心原理

目录 传送门前言一、事件和监听器1、生命周期监听2、事件触发时机 二、自动配置原理1、入门理解1.1、自动配置流程1.2、SPI机制1.3、功能开关 2、进阶理解2.1、 SpringBootApplication2.2、 完整启动加载流程 三、自定义starter1、业务代码2、基本抽取3、使用EnableXxx机制4、完…

SaaS软件的配置化平台是如何实现个性化定制的?

SaaS(Software as a Service,软件即服务)是一种通过互联网提供软件的模式,用户无需安装和维护任何复杂的基础设施,只需通过网络连接即可使用软件。SaaS 供应商负责软件的维护、升级和可用性,用户则通过订阅…

智能体时代,AI正从“神坛”走向“人间”

从通用大模型到行业大模型:AI智能体引领新风口 在人工智能领域,一场深刻的变革正悄然发生。从昔日高高在上的通用大模型,到如今愈发接地气的行业大模型,AI的风向标已经鲜明地指向了AI智能体(AI Agent)&…

APO v0.4.0 发布:新增影响面分析;新增调用数据库指标;优化告警事件关联展示

APO 新版本 v0.4.0 正式发布!本次更新主要包含以下内容: 新增影响面分析,识别服务端点对服务入口的影响 服务入口是指业务被访问时调用的第一个服务端点,在调用拓扑图中处于最上游。服务入口直接反映了系统对外提供服务的状态&a…

基于SpringBoot+Vue+MySQL的手机销售管理系统

系统展示 用户前台界面 管理员后台界面 商家后台界面 系统背景 随着智能手机的普及和市场竞争的日益激烈,手机销售行业面临着前所未有的挑战与机遇。传统的手工记录和简单的电子表格管理方式已难以满足现代手机销售业务的需求,销售数据的混乱和管理效率低…

(done) 声音信号处理基础知识(2) (重点知识:pitch)(Sound Waveforms)

来源:https://www.youtube.com/watch?vbnHHVo3j124 复习物理知识: 声音由物体的振动产生 物体振动会导致空气分支振荡 某一处的空气气压变化会创造一个波 声音是机械波 空气的振荡在空间中传递 能量从空间中的一个点到另一个点 机械波需要媒介&#x…

DBNet 博客转载

论文地址:https://arxiv.org/abs/1911.08947 最后的文字概率还需要扩张d https://blog.csdn.net/weixin_46505265/article/details/134836652 https://paddlepedia.readthedocs.io/en/latest/tutorials/computer_vision/OCR/OCR_Detection/DBNet.html

ThreadLocal与AsyncLocal

简介 ThreadLocal 用于在多线程环境中创建线程局部变量,可以让每个线程独立地访问自己的变量副本,互不影响。 而 AsyncLocal 是 ThreadLocal 的异步版本,专门用于异步编程场景,在异步操作中它可以正确处理上下文切换。 ThreadLo…

【Python】探索 Elpy:Emacs 中的 Python 开发环境

可以短时间不开心,但别长时间不清醒。 对于使用 Emacs 编辑器的 Python 开发者来说,Elpy 是一个强大的集成开发环境(IDE),它通过整合多个 Emacs Lisp 和 Python 包,提供了一套完整的 Python 编程支持。本文…

MySQL基础篇的补充

前言: 查询语句的书写顺序 select > from > where > group by > having > order by > limit 查询语句的执行顺序 from > where > group by > having > select > order by > limit 这个很重要,提前再复习一下。…

vue入门小练习

文章目录 1.案例需求2.编程思路3.案例源码4.小结 1.案例需求 一个简易的计算器,其效果如下: 图片切换,其效果如下: 简易记事本,其效果如下: 2.编程思路 1.这个Vue.js应用实现了一个简单的计算器&#x…

检索索引对象中的重复值、删除重复值pandas.Index.duplicated

【小白从小学Python、C、Java】 【考研初试复试毕业设计】 【Python基础AI数据分析】 检索索引对象中的重复值、删除重复值 pandas.Index.duplicated [太阳]选择题 根据代码,下列哪个选项正确表示了去重后的结果? import pandas as pd idx pd.Index([1,…

图书管理系统小程序的设计

管理员账户功能包括:系统首页,个人中心,用户管理,图书分类管理,图书信息管理,我的待还处管理,图书归还管理,催还提醒管理,系统管理 微信端账号功能包括:系统…

如何实现接口幂等性?

概述 幂等,英文idempotent [aɪdempətənt] 幂等这个词源自数学,是数学中的一个概念,常见于抽象代数中,表达的是N次变换与1次变换的结果相同,在计算机的各个领域都借用了该概念 幂等函数或幂等方法,是指…

stm32单片机个人学习笔记6(EXTI外部中断)

前言 本篇文章属于stm32单片机(以下简称单片机)的学习笔记,来源于B站教学视频。下面是这位up主的视频链接。本文为个人学习笔记,只能做参考,细节方面建议观看视频,肯定受益匪浅。 STM32入门教程-2023版 细…

大模型Qwen2.5 家族的最新成员

阿里今天发布了 Qwen 家族的最新成员:Qwen2.5,包括语言模型 Qwen2.5,以及专门针对编程的 Qwen2.5-Coder 和数学的 Qwen2.5-Math 模型。 所有开放权重的模型都是稠密的、decoder-only 的语言模型,提供多种不同规模的版本&#xff…

某准网爬虫逆向

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、目标网站二、抓包分析 1.数据包2.逆向过程总结 前言 提示:这里可以添加本文要记录的大概内容: 例如:随着人工智能的不…

AI 时代的网络危机沟通计划

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

ICM20948 DMP代码详解(35)

接前一篇文章:ICM20948 DMP代码详解(34) 上一回终于解析完了inv_icm20948_initialize_lower_driver函数,本回回到icm20948_sensor_setup函数,继续往下进行解析。为了便于理解和回顾,再次贴出icm20948_senso…