5.8.3 TCP连接管理(一)TCP连接建立

news2025/1/11 14:55:47

5.8.3 TCP连接管理(一)TCP连接建立

我们知道TCP是面向连接的传输协议,在传输连接的建立和释放是每一次面向连接通信必不可少的过程,因此传输连接的管理使得传输连接的建立和释放的过程都能够正常的进行。

一、使用Wireshark查看TCP传输连接的管理过程

我们可以使用Wireshark可以直观的分析TCP的连接建立,数据通信和连接释放等全过程。

  1. 打开Wireshark选择监听的网卡

  2. 点击开始按钮,并在浏览器中输入清华大学网址并访问。为了能够检测到我们需要的TCP报文段,需要持续一小段时间后停止采集报文。

  3. 在Wireshark的显示过滤器输入过滤条件,ip.addr==166.111.4.100(这是清华大学网站对应的IP地址),只观察IP为166.111.4.100排除其他的干扰报文。

  4. 在Wireshark统计菜单栏中选择流量图,如图

    设置
    勾选限制显示过滤器、流类型选择TCP Flows、地址选择任何。

  5. 通过以上设置我们就可以观察TCP流。我们可以看到主机192.168.0.23访问清华大学网站的所有TCP报文段的交互情况。如图 TCP报文段 包括端口、序号、确认号、标志位等置位情况等等一目了然。

二、TCP连接建立过程

TCP连接建立采用的过程被称为TCP三次握手,TCP报文段首部SYN和FIN置1时报文段需要消耗一个序号,只有ACK置位的报文段是不需要消耗序号的。

如图

这是主机A:192.168.0.23与清华大学服务器B:116.111.4.100之间的TCP三次握手连接建立的过程。三次握手

  1. 第一步如图 第一步
    第一步主机A的TCP向服务器B的TCP发送的连接请求报文段,其首部中的同步比特SYN=1,同时选择一个初始序号Seq=0(这是一个相对序号。)

  2. 第二步如图 第二步
    第二步服务器的TCP收到连接请求报文段后发回确认,确认中ACK=1,这其中确认号字段Ack=1,因为之前的连接请求的SYN=1,需要消耗掉一个序号,所以服务器B此时希望接收的序号应该是’1’,即确认号Ack=1

    因为连接是双向的所以服务器B也发出和主机A的连接请求,在报文段当中同时也应该将SYN置为1,选择服务器自己的一个初始序号,Seq=0,当然这也是一个相对序号。

  3. 第三步如图
    第三步
    第三步,主机A的TCP收到此报文后,还要服务器B发出确认,其确认序号为序号Seq=1,注意由于ACK置一的报文段,并不消耗掉序号,所以在主机A发往服务器B的第一个数据的序号仍然是序号字段等于1。

以上就是通过Wireshark采集的TCP报文段验证了三次握手的过程。

三、三次握手补充

  1. 当然三次握手还有一个很重要的功能,就是通信双方协商最大报文段长度MSS的过程,当客户端发起一个TCP连接时,通过TCP中的SYN置一报文段中的MSS选项字段来协商TCP报文数据载荷的最大值,客户端的SYN报文的MSS值表示后续服务器发送的数据载荷的最大值限定。

    如图是FDDI网络和以太网进行协商一个MSS的一个过程。 MSS
    在FDDI网络中,它的默认的报文段的值是4312个字节,而以太网只能接受最大报文段长度值是1460个字节,所以双方只能协商出双方网络中取小的一个值,也就是1460个字节,从而避免产生网络的IP分片。

  2. TCP三次握手缺陷

    当然TCP三次握手并不完美,SYNflood是当前最为流行的拒绝服务攻击或者是分布式的拒绝服务攻击的方式之一。这就是一种利用TCP的三次握手中的缺陷而发送大量TCP伪造的请求,从而使得服务器资源耗尽,或者CPU负荷满载或者内存不足等连接方式。

    这种攻击方式的问题就出现在TCP的三次握手中。如图 SYNflood
    我们假设一个用户向服务器发送了SYN=1的报文之后,突然死机或者掉线了,那么此时服务器会发出SYN=1,ACK=1的报文之后是没有办法收到来自客户端的第三次的握手报文,这种情况下服务器只能是重新的去试探再一次的发出SYN=1,ACK=1的第二次的握手报文,并在等待一段时间之后丢弃没有完成的半连接,这段时间就被称为SYN Timeout时间,这个时间大概是从30秒到2分钟之间。

    这里一个用户出现这样的情况并不会导致服务器的宕机,但是如果有大量的恶意攻击者出现这种情况,服务器为了维护如此庞大的半连接的列表而耗费非常非常多的资源,即便是非常简单的保存遍历方式也会消耗非常多的CPU和内存的资源,同时还需要对半连接进行SYN+ACK的第二次握手报文的重试。如果TCP/IP的协议栈不够强大,最后的结果往往是堆栈溢出或崩溃。从而导致服务器端不能够接受客户端的正常请求。此时的服务器就是收到了SYNflood攻击也就是洪水攻击。

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

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

相关文章

UE4/5用GeneratedDynamicMeshActor网格细分静态网格体【用的是ue5建模模式的box,其他的没有作用】

目录 制作 逻辑: 效果: ​编辑 代码: 制作 前面和之前的流程一样,打开插件和继承GeneratedDynamicMeshActor创建一个蓝图: 逻辑: 两个函数对应了两种细分方法 上面的细分模式是:Loop细…

JupyterNotebook基本操作

目录 Jupyter notebook文件操作 创建文件 修改文件名 复制文件 移动文件 删除文件 上传文件 下载文件 Jupyter notebook单元格操作 内容类型 编辑模式 快捷键 对照表 命令模式 编辑模式 查看快捷键 进入Jupyter Notebook主界面“File”中 VSCode配置Jupyter…

Bootstrap 表单

文章目录 Bootstrap 表单表单布局垂直或基本表单内联表单水平表单支持的表单控件输入框(Input)文本框(Textarea)复选框(Checkbox)和单选框(Radio)选择框(Select&#xff…

【Go】Go 语言教程--介绍(一)

文章目录 Go 语言特色Go 语言用途第一个 Go 程序Go 语言环境安装UNIX/Linux/Mac OS X, 和 FreeBSD 安装Windows 系统下安装安装测试 Go 是一个开源的编程语言,它能让构造简单、可靠且高效的软件变得容易。 Go是从2007年末由Robert Griesemer, Rob Pike, Ken Thompso…

文生图技术stable diffusion入门实战

文章目录 0. 环境搭建0.1 Windows0.1.1 git环境安装0.1.2 python 环境搭建0.1.2.1 配置pip国内镜像源 0.1.3 stable diffusion环境搭建0.1.3.1 远程访问Stable diffusion 1. 基础知识1.1 Stable Diffusion Webui及基础参数1.2 参数说明 0. 环境搭建 0.1 Windows 0.1.1 git环境…

电子时钟制作(瑞萨RA)(3)----使用J-Link烧写程序到瑞萨芯片

概述 这一节主要讲解如何使用J-Link对瑞萨RA芯片进行烧录。 硬件准备 首先需要准备一个开发板,这里我准备的是芯片型号R7FA2E1A72DFL的开发板: 视频教程 https://www.bilibili.com/video/BV1kX4y1v7tL/ 电子时钟制作(瑞萨RA)----(2)使用串口进行程序…

初学spring5(八)整合MyBatis

学习回顾&#xff1a;初学spring5&#xff08;七&#xff09;AOP就这么简单 一、步骤 1、导入相关jar包 junit <dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version> </dependency>m…

如何使用RobotFramework编写好的测试用例

目录 概述 命名 测试套件命名 测试用例命名 关键字命名 setup和teardown的命名 文档 测试套件文档 测试用例文档 用户关键字文档 测试套件结构 测试用例结构 工作流测试 数据驱动测试 用户关键字 变量 变量的命名 传参和返回值 避免使用Sleep关键字 我们AT…

算法设计与分析 课程期末复习简记(更新中)

网络流 下面是本章需要掌握的知识 • 流量⽹络的相关概念 • 最⼤流的概念 • 最⼩割集合的概念 • Dinic有效算法的步骤 • 会⼿推⼀个流量⽹络的最⼤流 下面对此依次进行复习 首先看流量网络的相关概念 上面是课程PPT中的定义&#xff0c;真是抽象 实际上&#xff0c;我们直接…

Maynor的博客专家成长之路——暨2023年中复盘

文章目录 博客专家成长之路——暨2023年中复盘前言念念不忘的博客专家每天只做三件事敲代码写博客健健身 我的感悟 不足之处未来&#xff1a;和CSDN共同成长最后 博客专家成长之路——暨2023年中复盘 前言 ​ 2023年不知不觉已经过去了半年有余&#xff0c;也是时候作年中复盘…

WEB界面测试

目录 前言&#xff1a; 摘要: WEB界面测试&#xff0c;最大的难度之一可能就是兼容性测试了 WEB界面测试&#xff0c;注重用户体验 WEB界面测试&#xff0c;注意用户的使用习惯 前言&#xff1a; Web界面测试是一种通过模拟用户与Web应用程序的交互来验证其功能和用户体验…

基于自然语言处理的多模态模型_综述

A Survey on Multimodal Large Language Models&#xff1b; 论文链接&#xff1a;https://arxiv.org/pdf/2306.13549.pdf 项目链接(实时更新最新论文&#xff0c;已获1.8K Stars)&#xff1a;https://github.com/BradyFU/Awesome-Multimodal-Large-Language-Models 研究背景 …

线程安全问题之原因及解决方案

线程安全问题 根本原因代码结构原子性解决方案&#xff1a;synchronized 内存可见性问题解决方案 volatile 指令重排序问题wait和notify判定一个代码是否线程安全&#xff0c;一定要具体问题具体分析!!! 根本原因 根本原因&#xff1a;多线程抢占式执行&#xff0c;随机调度。 …

ESP8266-NodeMCU搭建Arduino IDE开发环境

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 一、准备工作二、搭建步骤1.打开Arduino IDE 首选项2.打开Arduino IDE的“开发板管理器”3.在Arduino IDE的开发板菜单中找到“NodeMCU开发板”4.设置Arduino IDE的…

实验二:子程序设计实验

一、实验目的闻明找强的的掌握于程府的定又和调用方法掌握子程布的程库设计与调试方法 实验要求. 说明实现本实验需要掌握的知识及本实验害要的实验环境 二、实验要求了解萄单汇师培长程产没计与调武了解江编语子能店定义了解汇编语着子程序设计 实验内容 阐明实验具体内容及实…

3. Linux组件之内存池的实现

文章目录 一、为什么需要内存池二、内存池的工作流程三、内存池的实现3.1 数据结构3.2 接口设计3.2.1 创建内存池3.2.2 内存池销毁3.2.3 内存分配1. 分配小块内存2. 分配大块内存 3.2.4 内存池的释放3.2.5 内存池重置 3.3 完整代码 一、为什么需要内存池 应用程序使用内存&…

【我们一起60天准备考研算法面试(大全)-第一天 1/60(排序、进制)】【每天40分钟,我们一起用60天准备 考研408-数据结构(笔试)】

专注 效率 记忆 预习 笔记 复习 做题 欢迎观看我的博客&#xff0c;如有问题交流&#xff0c;欢迎评论区留言&#xff0c;一定尽快回复&#xff01;&#xff08;大家可以去看我的专栏&#xff0c;是所有文章的目录&#xff09;   文章字体风格&#xff1a; 红色文字表示&#…

与彭老师交流(北京大学 心理与认知科学学院)

交流&#xff1a;主要是了解人家在做什么对什么感兴趣&#xff0c;和让人家知道你在做什么对什么感兴趣&#xff0c;然后你觉得未来可以做什么有价值的事情。 1.老师做的方向里面有包含利用人工智能这一块的知识&#xff0c;我觉得我是可以做的&#xff0c;机理这一块的东西我不…

MySQL数据库复合查询

文章目录 一、多表查询二、自连接三、子查询1.单行子查询2.多行子查询3.多列子查询4.在from子句中使用子查询 四、合并查询 一、多表查询 在实际开发中&#xff0c;我们需要查询的数据往往会来自不同的表&#xff0c;所以需要进行多表查询。下面我们用一个简单的公司管理系统&…

启动游戏提示缺少(或丢失)xinput1_3.dll的解决办法

在我们打开游戏的或者软件的时候&#xff0c;电脑提示“找不到xinput1_3.dll&#xff0c;无法继续执行此代码”怎么办&#xff1f;相信困扰着不少小伙伴&#xff0c;我再在打开吃鸡的时候&#xff0c;然后花了一上午的时候时间研究&#xff0c;现在终于知道xinput1_3.dll文件是…