中科大 计算机网络8 协议层次和服务模型

协议层次

在这里插入图片描述

协议层次:现实生活中的例子

在这里插入图片描述
在这里插入图片描述

分层

分层处理和实现复杂系统
图中,左边是模块,右边是分层
计算机的设计是分层,每一层实现一个或一组功能,下层向上层提供服务;但效率比较低

在这里插入图片描述
对等层实体通过协议来交换数据信息【PDU协议数据单元,是指对等层次之间传递的数据单位】,通过层间的接口访问下层所提供的服务;通过层间的接口再向上层提供更好的服务
递归地

在这里插入图片描述

在这里插入图片描述

服务和服务访问点

套接字Socket就是层间的SAP(服务访问点)

在这里插入图片描述
服务提供者向服务用户提供服务,地点是服务访问点【SAP,层间接口】,形式是原语

Socket ApI【应用层使用传输层提供的服务】中的一系列函数就是原语【提供的是什么类型的服务】
在这里插入图片描述

服务的类型

面向连接的服务:
如:TCP
两个应用进程要先握手
无连接的服务;
如:UDP
在这里插入图片描述
在这里插入图片描述

服务和协议

协议:对等层实体
服务:在一个系统的内部,相邻两层之间,服务的接口上,服务提供者在SAP上使用原语向服务用户提供服务
在这里插入图片描述

数据单元DU

SDU:服务数据单元,上层要求传的信息
ICI:接口控制信息,传输时经过层间接口的加上的控制信息【接口控制信息,它是一种特殊的数据结构,进行层与层之间的数值传递】
IDU=ICI+SDU【接口数据单元】

上层来的SDU+头部(本层的ICI【接口控制信息】…)=PDU【本层地协议数据单元】

SDU非常小:
组合【多对一】
在这里插入图片描述

SDU一般状况:
【一对一】
在这里插入图片描述
SDU很大:
SDU分割【一对多】
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

Internet协议栈

在这里插入图片描述
物理层:传输一个个比特
数据链路层:传输帧,在相邻的两点之间传输以帧为单位的数据【point to point】
网络层:源主机到目标主机端到端的传输,以分组为单位【end to end】
传输层:进程到进程的区分,把网络层提供的不可靠的服务变为可靠的服务【TCP】
应用层:完成应用报文的交互
在这里插入图片描述
TCP/IP协议栈【互联网协议栈】:
路由:全局
转发:局部
在这里插入图片描述
OSI参考模型【七层】
ISO:国际标准化组织
OSI是Open System Interconnection的缩写,意为开放式系统互联。

表示层:为异种机通信提供一种公共语言,以便能进行互操作。
会话层:会话管理;建立,维持会话等

表示层和会话层的功能在TCP/IP协议中由应用层去实现
在这里插入图片描述

封装和解封装

网卡:集成了数据链路层和物理层的功能

网卡B【交换机B】从网口收到网卡A【交换机A】的帧,找到帧头帧尾的数据部分–分组,根据分组里面的目标IP地址查交换机的栈表或交换表,决定通过哪个端口发出去,由
端口封装为这条链路的帧,然后交给它的物理层,物理层把帧中的每一个比特变为物理信号/光信号,把它发送出去,就可以到达下一跳

源端:大的封装
中间部分:交换节点做一个两层的解封装与封装【路由器(网络层)】或三层的解封装与封装【交换机(数据链路层)】
目标端:大的解封装
在这里插入图片描述
在这里插入图片描述

各层次的协议数据单元叫法

PDU:协议数据单元
在这里插入图片描述

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

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

相关文章

STL源码剖析 heap堆结构

heap一般特指max-heap,即最大的元素位于heap和array的首部 heap不提供遍历功能,也不提供迭代功能

中科大 计算机网络9 互联网历史

总纲 计算机网络 早期1960以前 1961-1972 NCP协议:相当于现在的TCP和IP协议 每个节点即是数据的源也是数据的目标

STL源码剖析 序列式容器 slist

STL l i s t 是个双向链表(double linked lis t) 。SGI STL提供了一个单向链 表 (single linked lis t) , 名 为 slist s l i s t 和 l i s t 的主要差别在于,前者的迭代器属于单向的Forwardlterotor, 后者的迭代器属于双向的Bidirectional Iterator.为此&#xff0…

中科大 计算机网络12 Web和HTTP

Web与HTTP 对象:web页中其实是对象链接 URL:通用资源定位符【任何对象都可以使用URL来唯一标识】 用户名:口令【支持匿名访问,用户名和口令不计】 端口:HTTP:80 FTP:21【使用默认端口号&#x…

STL源码剖析 关联式容器 树 红黑树、二叉搜索树、平衡二叉搜索树

所谓关联式容器,观念上类似关联式数据库(实际上则简单许多):每笔数据(每个元素)都有一个键值(key)和一个实值(value) 2。当元素被插入到关联式 容器中时,容器内部结构(可能是RB-tree,也可能是hash-table)便依照其键 值大小,以某种…

北京大学 软件工程1 软件 软件工程 软件开发 软件工程框架

软件的定义 重新定义软件 新一代信息技术 区块链 创造性思维 软件的特点 软件的种类 支撑软件:VC,PyCharm等 应用软件:QQ,微信 软件工程的起源 软件开发的三个阶段 软件工程概念的提出 软件工程的定义 软件工程将系统化&#…

java学习_Python基础学习教程:从0学爬虫?让爬虫满足你的好奇心

Python基础学习教程:从0学爬虫?让爬虫满足你的好奇心有必要学爬虫吗?我想,这已经是一个不需要讨论的问题了。爬虫,“有用”也“有趣”!这个数据为王的时代,我们要从这个庞大的互联网中来获取到我…

安卓rom制作教程_安卓手机TWRP_Recovery卡刷图文教程 适用于卡刷ROM,TWRP救砖

扫一扫二维码,关注我,解决刷机各种疑难杂症 ROM乐园独家支持最近有很多小伙伴问怎么去卡刷,卡刷的操作是什么,什么是卡刷,小编就仔细来写一下卡刷教程吧,记住,我们所说的卡刷,并不是…

东软 软件工程1 软件危机 软件工程 软件生命周期

软件危机 软件危机产生的原因 消除软件危机的途径: 软件工程历史 软件工程的概念 软件工程项目的基本目标 软件工程的基本原理 软件生命周期 软件工程的中的软件生命周期

东软 软件工程2 软件开发模型 瀑布模型 原型模型 螺旋模型 统一过程模型RUP 敏捷开发模型

软件开发过程模型 瀑布模型 原型模型 螺旋模型 统一过程模型-RUP 敏捷开发模型 敏捷开发模型:Scrum方法 敏捷开发模型:进行Scrum开发

自动点击器一秒200_做PPT还需要找模板?用这招3分钟就能自动排好PPT!

点击上图直达活动详情页,优惠券超 400 元!大家好,我是爱挖神器的洁洁。今天我来跟大家聊聊「PPT里的神器」~我们每次做 PPT 的时候,经常面对的一个难题就是:如!何!排!版 ?比如像这样…

东软 软件工程3 软件项目管理 团队组织管理

团队组织管理 团队的概念 项目组的组织原则 项目组的组织方式 软件项目管理过程组

dedecms怎么改php版本_玩转Termux:手把手教你在手机上安装php与nginx!

大家好,这里是 「手机编程」,我是作者:舞剑,记得「关注我」今天是Termux系列第三节,我来讲讲怎么安装 PHP 与 Mysql,然后用 Termux 搭建一个网站。PHP全球有几乎95%的网站都使用 php 需要编写的&#xff0c…

Python学习8 函数 匿名函数 内置函数

转换相关的方法-eval 转换相关的方法-json 函数基本语法大纲 函数概念 示例: 题目: 函数的参数 def f(x,y1,*z,**abc):print(x,y,z,abc,sep"\n")f(1,4,5,3,a1,b2,c3) #1 # 4 # (5, 3) # {a: 1, b: 2, c: 3}易错题: 1&#xff0…

求两个集合的交集

letcode原题 排序双指针 如果两个数组是有序的,则可以使用双指针的方法得到两个数组的交集。首先对两个数组进行排序,然后使用两个指针遍历两个数组。初始时,两个指针分别指向两个数组的头部。每次比较两个指针指向的两个数组中的数字&#…

Python学习7 集合Set

区别 集合的基本使用 如果是空集合,使用set {}是字典 pop:无序,随机删除一个元素 add添加一个元素 remove移除指定元素 update合并,合并在原集合上 union合并到一个新的集合上 clear清空 总结: 集合运算 补集: f…

cad怎么快速算面积_用cad算面积的快捷键方法步骤详细,大朗CAD培训班

在绘图的过程中经常需要查询和计算图形的面积,网上有不少人问这方面的问题。都市领航教育将计算面积的方法和相关命令整理一下,希望对初学者有帮助。 查询图形的面积 我们利用边界或编辑多段线命令生成了多段线和面域,不需要再使用查询面积命…

给定没有重复数字的序列,将其全排列

leetcode题目 void backtrack(vector<vector<int>>& res, vector<int>& output, int first, int len){if (firstlen){res.push_back(output);}for (int i first; i < len; i) {std::swap(output[first],output[i]);backtrack(res,output,first1,…