(chap2 TCP/IP基础知识) TCP/IP分层模型的通信流程

2024-03-28 09:32

本文主要是介绍(chap2 TCP/IP基础知识) TCP/IP分层模型的通信流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 每个分层中,都会对所发送的数据附件一个首部,在这个首部中包含了该层次必要的信息,如发送的目标地址以及协议相关信息。
在这里插入图片描述

1.1 数据单位


  • 全能性术语。

  • 表示数据链路层中包的单位。
  • 数据报
    IP和UDP 等网络层以上的分层中包的单位。

  • 表示TCP数据中流的信息。
  • 消息
    指应用协议中数据的单位。

网络中传输的数据包由两部分组成,首部加数据。首部用来标明协议如何读取数据。

1.2 经过数据链路层的包:每个包首部中至少都会有两个信息,一个为发送端和接受端地址,另一个为上一层协议类型。

1.2.1 TCP包首部

  • 以太网:MVC地址
  • IP:IP地址
  • TCP/UDP:端口号

1.2.2 IP包首部

  • 接受端IP地址
  • 发送端IP地址
  • 用来判断其后数据是TCP还是UDP的信息。

1.2.3 以太网包首部

  • 接受端的MAC地址
  • 发送端MAC地址
  • 标志以太网的类型数据

在这里插入图片描述

2. 通信流程(以发送邮件为例)

2.1 发送流程

step1. 应用程序处理

应用程序会进行编码处理(ISO表示层),建立通信连接发送数据(ISO会话层),在发送邮件的时候建立TCP连接。

step2.TCP模块处理

  • 根据应用的指示,负责建立连接,发送数据以及断开连接。
  • TCP提供将应用层发来的数据帧顺利的发送到对端的可靠传输。需要在应用层数据前端附件TCP首部,(包含源端口号和目标端口号,序号(发送的是包中那部分数据)以及校验和(判断数据是否损坏),之后将附加TCP首部的包发给IP。

step3.IP模块处理

将TCP传过来的TCP首部和TCP数据合起来当做自己的数据,并在TCP首部的前端在加上自己的IP首部。

IP包生成后参考路由控制表决定接受此IP包的路由或主机,IP包将被发送给连接路由器或主机网络接口的驱动程序,可以利用ARP查找IP地址对应的MAC地址。

step4.网络接口(以太网驱动)的处理

从IP传过来IP包,以太网驱动会在数据上附加以太网首部并进行发送处理,以太网数据包通过物理层传输给接收端。FCS由硬件计算,添加到包的最后(判断数据包是否被破坏)。

在这里插入图片描述

2.2 接收数据流程(接受处理是发送端的逆序过程)

step5. 网络接口(以太网驱动)的处理

主机收到以太网包后,从以太网的包首部找到MAC地址判断是否发给自己

  • 若不是,就丢弃数据。
  • 若是,就查找以太网包首部中的类型域从而确定以太网协议所传送过来的数据类型。

step6. IP模块的处理

a. 判断得出包首部中的IP地址与自己的IP地址匹配
b. 若匹配,接受数据并从中查找上一层协议,如果为TCP就给TCP处理,如果为UDP就给UDP处理
c. 接收端地址往往不是自己的地址,需要借助路由控制表找到应该送往的主机或路由器。

step7. TCP模块处理

a. 计算一下校验和,判断是否被破坏
b. 检查是否是按照序号接收数据
c. 检查端口号,确定具体的应用程序。
d. 数据接收完成会返送“确认回执”,若接收端未能接收,发送端会一直发送。

step8. 应用程序的处理

接收端应用程序会直接接收发送端发送的数据,如果未能成功接收,就发送一个“处理异常”的回执给发送端。

3. eg. SNS(Social Network Service ),社交网络是一种即使共享,使发布消息该圈内特定联系人的一种服务。
在这里插入图片描述

这篇关于(chap2 TCP/IP基础知识) TCP/IP分层模型的通信流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java通过ServerSocket与Socket实现通信过程

《Java通过ServerSocket与Socket实现通信过程》本文介绍了Java中的ServerSocket和Socket类,详细讲解了它们的构造方法和使用场景,并通过一个简单的通信示例展示了如何... 目录1 ServerSocket2 Socket3 服务器端4 客户端5 运行结果6 设置超时总结1

Apache服务器IP自动跳转域名的问题及解决方案

《Apache服务器IP自动跳转域名的问题及解决方案》本教程将详细介绍如何通过Apache虚拟主机配置实现这一功能,并解决常见问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录​​问题背景​​解决方案​​方法 1:修改 httpd-vhosts.conf(推荐)​​步骤

Linux(centos7)虚拟机没有IP问题及解决方案

《Linux(centos7)虚拟机没有IP问题及解决方案》文章介绍了在CentOS7中配置虚拟机网络并使用Xshell连接虚拟机的步骤,首先,检查并配置网卡ens33的ONBOOT属性为yes,然后... 目录输入查看ZFhrxIP命令:ip addr查看,没有虚拟机IP修改ens33配置文件重启网络Xh

Java领域模型示例详解

《Java领域模型示例详解》本文介绍了Java领域模型(POJO/Entity/VO/DTO/BO)的定义、用途和区别,强调了它们在不同场景下的角色和使用场景,文章还通过一个流程示例展示了各模型如何协... 目录Java领域模型(POJO / Entity / VO/ DTO / BO)一、为什么需要领域模

在DataGrip中操作MySQL完整流程步骤(从登录到数据查询)

《在DataGrip中操作MySQL完整流程步骤(从登录到数据查询)》DataGrip是JetBrains公司出品的一款现代化数据库管理工具,支持多种数据库系统,包括MySQL,:本文主要介绍在D... 目录前言一、登录 mysql 服务器1.1 打开 DataGrip 并添加数据源1.2 配置 MySQL

深入理解Redis线程模型的原理及使用

《深入理解Redis线程模型的原理及使用》Redis的线程模型整体还是多线程的,只是后台执行指令的核心线程是单线程的,整个线程模型可以理解为还是以单线程为主,基于这种单线程为主的线程模型,不同客户端的... 目录1 Redis是单线程www.chinasem.cn还是多线程2 Redis如何保证指令原子性2.

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

Spring Boot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)

《SpringBoot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)》本文将以一个实际案例(用户管理系统)为例,详细解析SpringBoot中Co... 目录引言:为什么学习Spring Boot分层架构?第一部分:Spring Boot的整体架构1.1

Python的pandas库基础知识超详细教程

《Python的pandas库基础知识超详细教程》Pandas是Python数据处理核心库,提供Series和DataFrame结构,支持CSV/Excel/SQL等数据源导入及清洗、合并、统计等功能... 目录一、配置环境二、序列和数据表2.1 初始化2.2  获取数值2.3 获取索引2.4 索引取内容2

nodejs打包作为公共包使用的完整流程

《nodejs打包作为公共包使用的完整流程》在Node.js项目中,打包和部署是发布应用的关键步骤,:本文主要介绍nodejs打包作为公共包使用的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言一、前置准备二、创建与编码三、一键构建四、本地“白嫖”测试(可选)五、发布公共包六、常见踩坑提醒