【网络编程开发】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

相关文章

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

在Node.js中使用.env文件管理环境变量的全过程

《在Node.js中使用.env文件管理环境变量的全过程》Node.js应用程序通常依赖于环境变量来管理敏感信息或配置设置,.env文件已经成为一种流行的本地管理这些变量的方法,本文将探讨.env文件... 目录引言为什么使php用 .env 文件 ?如何在 Node.js 中使用 .env 文件最佳实践引

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

Python实现简单封装网络请求的示例详解

《Python实现简单封装网络请求的示例详解》这篇文章主要为大家详细介绍了Python实现简单封装网络请求的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录安装依赖核心功能说明1. 类与方法概览2.NetHelper类初始化参数3.ApiResponse类属性与方法使用实

python库pydantic数据验证和设置管理库的用途

《python库pydantic数据验证和设置管理库的用途》pydantic是一个用于数据验证和设置管理的Python库,它主要利用Python类型注解来定义数据模型的结构和验证规则,本文给大家介绍p... 目录主要特点和用途:Field数值验证参数总结pydantic 是一个让你能够 confidentl

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求:

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建