【网络编程开发】8.TCP连接管理与UDP协议 9.IP协议与ethernet协议

2024-06-09 00:36

本文主要是介绍【网络编程开发】8.TCP连接管理与UDP协议 9.IP协议与ethernet协议,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

8.TCP连接管理与UDP协议

三次握手

三次握手的过程在TCP/IP网络通信中起着至关重要的作用,它不仅确保了数据的可靠传输,还为两端的数据传输提供了稳定的连接初始化过程。这一过程涉及到几个关键步骤,每个步骤都有其特定的目的和功能。

在这里插入图片描述

步骤

  1. 初始化:B 的 TCP 服务器进程先创建传输控制块 TCB,准备接受客户进程的连接请求。
  2. 第一次握手
    • A 的 TCP 向 B 主动发出连接请求报文段,其包头中的同步位 SYN = 1,并选择序号 seq = x,表明传送数据时的第一个数据字节的序号是 x。
    • 注意:TCP规定,SYN 报文段(即SYN = 1的报文段)不能携带数据,但要消耗掉一个序号。
    • 通过这一步,服务器知道了客户端具有发送数据的能力,但此时服务器还未确认自己能够接收和发送数据到客户端。
  3. 第二次握手
    • B 的 TCP 收到连接请求报文段后,如同意,则发回确认。
    • B 在确认报文段中应使 SYN = 1,使 ACK = 1,其确认号 ack = x + 1,自己选择的序号 seq = y。
    • 这个报文段也不能携带数据,但同样要消耗掉一个序号。
    • 通过这一步,客户端确认了服务器既能接收数据也能发送数据。
  4. 第三次握手
    • A 收到此报文段后向 B 给出确认,其 ACK = 1,确认号 ack = y + 1。
    • A 的 TCP 通知上层应用进程,连接已经建立。
    • TCP 标准规定:ACK 报文段可以携带数据。
      但如果不携带数据,则不消耗序号。下一个数据报文段的序号仍是 seq = x + 1。
    • 这一步完成了整个握手过程,现在服务器知道客户端既能接收数据也能发送数据。只有当服务器收到这个最后的ACK包时,连接才算正式建立,随后双方可以开始数据传输。
  5. 数据开始传输:B 的 TCP 收到主机 A 的确认后,也通知其上层应用进程:TCP 连接已经建立。双方可以开始数据传送。

四次挥手

四次挥手过程是TCP连接释放的核心机制,它确保了数据传输的完整性和可靠性。在网络通信中,TCP(传输控制协议)提供可靠的、面向连接的服务,确保数据在互联网中的准确传输。这一过程中,“四次挥手”是TCP协议关闭连接的一个重要环节,它涉及客户端和服务器之间的数据交换确认,确保双方都没有数据传输后,才正式关闭连接。

在这里插入图片描述

TCP四次挥手的过程具体如下:

  1. 第一次挥手:当一端(通常是客户端)完成数据发送后,会向另一端(服务器)发送一个FIN报文,试图关闭这一方向的连接。此时,客户端不再发送数据,但可以接受数据。
    • A 的应用进程先向其 TCP 发出连接释放报文段,并停止再发送数据,主动关闭 TCP 连接。
    • A 把连接释放报文段首部的 FIN = 1,其序号seq = u,等待 B 的确认。
    • TCP规定:FIN 报文段即使不携带数据,也消耗掉一个序号。
  2. 第二次挥手:另一端(服务器)收到这个FIN报文后,会发送一个ACK报文作为响应,确认序号ack为收到的序号加1,表明已经接收到客户端的关闭请求,此时服务器还可以继续发送数据。
    • B 发出确认,ACK=1,确认号 ack = u+1,这个报文段的序号 seq = v。
    • TCP 服务器进程通知高层应用进程。
    • 从 A 到 B 这个方向的连接就释放了,TCP 连接处于半关闭 (half-close) 状态。B 若发送数据,A 仍要接收。
  3. 第三次挥手:当服务器也没有数据需要发送时,同样会发送一个FIN报文给客户端,表示自己也准备关闭连接。
    • 若 B 已经没有要向 A 发送的数据,其应用进程就通知 TCP 释放连接。
    • FIN=1,ACK=1,确认号 ack = u+1。
  4. 第四次挥手:客户端收到来自服务器的FIN报文后,会发送ACK报文进行确认,ack序列号设为收到的序号加1。此后,客户端进入TIME_WAIT状态,等待2MSL(最大段生存时间)以确保对方正确接收到了ACK报文。之后,客户端也会关闭连接。
    • A 收到连接释放报文段后,必须发出确认。
    • ACK=1,确认号 ack=w+1,自己的序号 seq = u + 1

保活计时器

  • 用来防止在 TCP 连接出现长时期空闲。

  • 通常设置为 2 小时 。

  • 若服务器过了 2 小时还没有收到客户的信息,它就发送探测报文段。

  • 若发送了 10 个探测报文段(每一个相隔 75 秒)还没有响应,就假定客户出了故障,因而就终止该连接。

9.IP协议与ethernet协议

IP 数据报首部的固定部分中的各字段

在这里插入图片描述

  1. 版本(Version):这个字段占4位,用于标识IP数据报遵循的IP协议版本。常见的版本有IPv4(0100)和IPv6(0110)。版本字段确保了与相应IP版本的兼容性。
  2. 首部长度(Header Length):用4位表示,说明IP数据报首部的长度。由于单位是4字节,首部长度的最大值为60字节。通常首部长度为20字节,这适用于大多数情况。
  3. 服务类型(Type of Service):占8位,旧称服务类型(Service Type),在现代网络中被称为区分服务(Differentiated Services)。该字段用于处理特殊服务要求,如低延迟、高可靠性等。
  4. 总长度(Total Length):总长度字段为16位,表明整个IP数据报的长度,包括首部和数据载荷。其单位为字节,因此数据报的最大长度可达65535字节。这个字段对于确定数据报的大小及是否需要分片至关重要。
  5. 标识(Identification):这是一个16位的字段,用于唯一标识一个IP数据报。相同的标识值意味着分片来源于同一个IP数据报。这在分片后的重组过程中是必不可少的。
  6. 标志(Flags):占3位,其中关注最多的是最后两位。最低位是MF(More Fragments),若设置为此位,则表示后面还有更多分片。中间位是DF(Don’t Fragment),若设置为此位,则不允许对该数据报进行分片处理。
  7. 片偏移(Fragment Offset):这个13位的字段指示分片相对于原始数据报的偏移量,以8字节为单位。这对于接收端正确重组分片非常重要。
  8. 生存时间(Time to Live, TTL):占8位,用于设置数据报可以经过的最多路由器数。每经过一个路由器,TTL减1,当TTL减至0时,数据报被丢弃,从而防止数据报在网络中无限循环。
  9. 协议(Protocol):此8位字段表明数据报的数据部分使用的协议类型,例如TCP、UDP或ICMP。
  10. 首部检验和(Header Checksum):这个16位的字段仅对数据报的首部进行错误检查,保证首部的正确性。数据部分的错误检测由更高层的协议负责。

此外,还有源IP地址和目标IP地址字段,各占4字节。这两个字段分别指定了发送数据报的主机和数据报目的地的IP地址。

分片

在这里插入图片描述

  • 假设一个IP数据报首部20字节,数据部分3800字节,需要分片。由于MTU限制为1500字节,每个分片的最大数据长度应为1480字节(1500字节扣除20字节首部)。

  • 分片处理开始,首先根据1480字节的限制,将数据分为三个分片。第一个分片包含首部和前1400字节的数据,第二个分片包含首部和接下来的1400字节的数据,第三个分片包含剩余的数据和首部。

  • 每个分片的标识相同,表明它们属于同一个IP数据报。第一个和第二个分片的MF标志设置为1,表示后续还有更多分片。最后一个分片的MF标志设置为0,表示这是最后一个分片。

  • 片偏移量分别设置为0, 175, 和350(以8字节为单位),这表示每个分片的数据部分在原始数据报中的相对位置。

Ethernet协议

Ethernet协议是一种重要的链路层协议,专门用于实现局域网(LAN)内的数据传输和地址封装

Ethernet协议由DIX联盟开发,是计算机网络中应用最广泛的局域网通信协议之一。该协议基于冲突检测的共享媒体访问控制方法,允许多个设备在同一个局域网上同时传输数据。

以太网 V2 的 MAC 帧格式

在这里插入图片描述

  1. 类型字段
    • 2字节
    • 类型字段用来标志上一层使用的是什么协议,
    • 以便把收到的 MAC 帧的数据上交给上一层的这个协议。
  2. 数据字段
    • 46 ~ 1500 字节
    • 数据字段的正式名称是 MAC 客户数据字段。
    • 最小长度 64 字节 - 18 字节的首部和尾部 = 数据字段的最小长度(46字节)
  3. 无效的 MAC 帧
    • 数据字段的长度与长度字段的值不一致;
    • 帧的长度不是整数个字节;
    • 用收到的帧检验序列 FCS 查出有差错;
    • 数据字段的长度不在 46 ~ 1500 字节之间。有效的 MAC 帧长度为 64 ~ 1518 字节之间。
    • 对于检查出的无效 MAC 帧就简单地丢弃。以太网不负责重传丢弃的帧。

这篇关于【网络编程开发】8.TCP连接管理与UDP协议 9.IP协议与ethernet协议的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1043759

相关文章

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma

电脑win32spl.dll文件丢失咋办? win32spl.dll丢失无法连接打印机修复技巧

《电脑win32spl.dll文件丢失咋办?win32spl.dll丢失无法连接打印机修复技巧》电脑突然提示win32spl.dll文件丢失,打印机死活连不上,今天就来给大家详细讲解一下这个问题的解... 不知道大家在使用电脑的时候是否遇到过关于win32spl.dll文件丢失的问题,win32spl.dl

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解

Windows Server服务器上配置FileZilla后,FTP连接不上?

《WindowsServer服务器上配置FileZilla后,FTP连接不上?》WindowsServer服务器上配置FileZilla后,FTP连接错误和操作超时的问题,应该如何解决?首先,通过... 目录在Windohttp://www.chinasem.cnws防火墙开启的情况下,遇到的错误如下:无法与

nvm如何切换与管理node版本

《nvm如何切换与管理node版本》:本文主要介绍nvm如何切换与管理node版本问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录nvm切换与管理node版本nvm安装nvm常用命令总结nvm切换与管理node版本nvm适用于多项目同时开发,然后项目适配no