计算机网络——数据链路层-点对点协议(组成部分、PPP帧格式、透明传输、差错检测、工作状态)

目录

介绍

组成部分 

PPP帧格式

透明传输

字节填充法 

比特填充法 

差错检测

工作状态


本篇我们介绍点对点协议PPP

介绍

点对点协议PPPPoint-to-Point Protocol)是目前使用最广泛的点对点数据链路层协议。

请大家想想看:一般的英特网用户,是如何接入到英特网的呢?

通常都是要通过连接到某个英特网服务提供者ISP(例如中国电信、中国联通、中国移动
这三大运营商)才能接入英特网。这些ISP已经从英特网管理机构申请到了一批IP地址,用户计算机只有获取到ISP所分配的合法IP地址后,才能成为英特网上的主机。

用户计算机与SP进行通信时所使用的数据链路层协议,通常就是PPP协议 。

这里需要说明的是:

在1999年公布的在以太网上运行的PPP协议,即PPP over Ethernet。简称为PPPoE。

它使得ISP可以通过DSL、电路调制解调器、以太网等宽带接入技术,以以太网接口的形式为用户提供接入服务。

另外,点对点协议PPP也广泛应用于广域网路由器之间的专用线路 。

PPP协议是因特网工程任务组IETF在1992年制定的。经过1993年和1994年的修订,现在的PPP协议已成为因特网的正式标准[RFC161,RFC1662]。

我们可以在ITF官方网站的相关页面,搜索并查看PPP协议的相关RFC文档。

小结 

  • 点对点协议PPPPoint-to-Point Protocol)是目前使用最广泛的点对点数据链路层协议。
  • PPP协议是因特网工程任务组IETF在1992年制定的。经过1993年和1994年的修订,现在的PPP协议已成为因特网的正式标准[RFC161,RFC1662]。

组成部分 

PPP协议为在点对点链路传输各种协议数据报提供了一个标准方法,主要由以下三部分构成:

  1. 对各种协议数据报的封装方法,也就是之前文章中介绍的封装成帧
  2. 链路控制协议LCP,用于建立、配置以及测试数据链路的连接
  3. 一套网络控制协议NCPs,其中的每一个协议支持不同的网络层协议

从网络体系结构的角度看,PPP是数据链路层的协议;它将上层交付下来的协议数据单元封装成PPP帧,为了支持不同的网络层协议,PPP协议包含了一套网络控制协议NCPs,其中的每一个协议支持不同的网络层协议。(例如TCP/IP中的IP、Novell NetWare网络操作系统中的IPX、Apple公司的AppleTalk等)。链路控制协议LCP用于建立、配置以及测试数据链路的连接PPP协议
能够在多种类型的点对点链路上运行(例如面向字节的异步链路、面向比特的同步链路)。

PPP帧格式

接下来我们来看看PPP协议的帧格式:

帧首部由四个字段构成,帧尾部由两个字段构成 ,各字段的长度以及帧的数据部分的最大长度如下图所示:

帧首和帧尾部中的标志字段(F,Flag)是PPP帧的定界符,取值为16进制的7E;

帧首部中的地址字段(A,Address)取值为十六进制的FF;

控制字段(C,Control)取值为十六进制的03(最初曾考虑以后再对A和C这两个字段的值进行其他定义,但至今也没有给出,可见这两个字段实际上并没有携带PPP针的信息);

帧首部中的协议字段(P,Protocol)指明了帧的数据部分应送交哪个协议处理。当协议字段取值为16进制的0021时,PPP帧的数据部分就是IP数据报、当协议字段取值为十六进制的C021时,PPP帧的数据部分就是链路控制协议LCP的分组、当协议字段取值为16进制的8021时,PPP帧的数据部分就是网络控制协议NCP的分组;

帧尾部中的帧检验序列FCS字段(Frame Check Sequence),其值是使用循环冗余校验CRC计算出的,校验位用于检查PPP帧是否存在误码。

透明传输

接下来我们来看看PPP协议是如何解决透明传输问题的。

当PPP帧的数据部分出现帧首和帧尾中的标志字段时,如果不采取措施,则会造成接收方对PPP帧是否结束的误判;因为标志字段是PPP帧的定界符,取值为十六进制的7E,也就是二进制的0111 1110。

PPP协议实现透明传输的方法取决于所使用的链路类型,如果是面向字节的异步链路,则采用字节填充法,也就是插入‘转义字符’。

如果是面向比特的同步电路,则采用比特填充法,也就是插入‘比特0’。

字节填充法 

举例说明字节填充法,也就是以字节7E作为PPP帧的定界符,以字节为单位来讨论问题。

发送方对PPP帧数据部分的处理应为:

将出现的每一个7E字节转变成两字节序列7D、5E。如图所示:

这相当于在7E字节前插入了转义字节7D,并将7E字节减去16进制的20;

将出现的每一个7D字节转变成两字节序列7D、5D。如图所示:

在出现的每一个ASCII码控制字符前插入一个7D字节,同时将该字符的编码加上16进制的20。例如图中所示:

对于PPT帧的接收方,只要进行反变化即可恢复出原来的PPT帧的数据部分。

比特填充法 

再来举例说明比特填充法,也就是以0111 1110作为PPP帧的定界符,以比特为单位来讨论问题。

假设PPP帧的数据部分如下图所示:

其中包含了两个帧定界符。

来看发送方对PPP帧数据部分的处理:

对帧的数据部分进行扫描(一般由硬件实现),只要发现5个连续的比特1,则立即填充一个比特0,如下图所示:

再来看接收方对PPP帧数据部分的处理:

对帧的数据部分进行扫描(一般由硬件实现),只要发现5个连续的比特1,就把其后的一个比特0删除。

差错检测

接下来我们来看看PPP协议是如何进行差错检测的。

PPP帧的尾部包含有一个两字节的帧检验序列FCS字段,使用循环冗余校验CRC来计算该字段的取值。

采用的生成多项式如下所示:

RFC1662文档的附录部分给出了FCS的计算方法的C语言实现,为了减少对CPU的占用
采用查表法来实现。

FCS的计算范围如下图所示:

接收方每收到一个PPP帧,就进行CRC检验。若CRC检验正确,就收下这个帧;反之就丢弃这个帧。使用PPP的数据链路层向上不提供可靠传输服务

工作状态

PPP链路的开始和结束状态都是静止状态,这时并不存在物理层的连接。

  • 当检测到调制解调器的载波信号,并建立物理层连接后,PPP就进入链路的建立状态,这时列入控制协议LCP开始协商一些配置选项。
  1. 若协商成功则进入鉴别状态
  2. 若协商失败,则退回到静止状态

所协商的配置选项包括最大帧长、鉴别协议等,可以不使用鉴别、也可以使用口令鉴别协议PAP或挑战握手鉴别协议CHAP。

  • 若通讯双方无需鉴别或鉴别身份成功,则进入网络状态;若鉴别失败则进入终止状态。

进入网络状态后进行NCP配置,PPP链路的两端通过相互交换网络层特定的NCP分组来进行NCP配置。如果在PPP链路上运行的是IP协议,则使用IP控制协议IPCP来对PPP链路的每一端配置IP模块(例如分配IP地址)。

  • 配置完成后就进入打开状态,只要链路处于打开状态就可以进行数据通信。
  • 当出现故障或链路的一端发出终止请求时,就进入终止状态。
  • 当载波停止后则回到静止状态。

END


学习自:湖科大——计算机网络微课堂

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

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

相关文章

算法模板之队列图文详解

🌈个人主页:聆风吟 🔥系列专栏:算法模板、数据结构 🔖少年有梦不应止于心动,更要付诸行动。 文章目录 📋前言一. ⛳️模拟队列1.1 🔔用数组模拟实现队列1.1.1 👻队列的定…

Kafka集群架构服务端核心概念

目录 Kafka集群选举 controller选举机制 Leader partition选举 leader partition自平衡 partition故障恢复机制 follower故障 leader故障 HW一致性保障 HW同步过程 Epoch Kafka集群选举 1. 在多个broker中, 需要选举出一个broker, 担任controller. 由controller来管理…

Hadoop入门学习笔记——三、使用HDFS文件系统

视频课程地址:https://www.bilibili.com/video/BV1WY4y197g7 课程资料链接:https://pan.baidu.com/s/15KpnWeKpvExpKmOC8xjmtQ?pwd5ay8 Hadoop入门学习笔记(汇总) 目录 三、使用HDFS文件系统3.1. 使用命令操作HDFS文件系统3.1.…

Flink系列之:深入理解ttl和checkpoint,Flink SQL应用ttl案例

Flink系列之:深入理解ttl和checkpoint,Flink SQL应用ttl案例 一、深入理解Flink TTL二、Flink SQL设置TTL三、Flink设置TTL四、深入理解checkpoint五、Flink设置Checkpoint六、Flink SQL关联多张表七、Flink SQL使用TTL关联多表 一、深入理解Flink TTL …

Simulink元件

constant 输出常数/标量 这样我们就只输出了一个常数 输出一维数组/矢量 这样我们就输出了1-5一共5个数字 输出二维数组 这样我们就输出了4个数字 选择框Interpret vector parameters as 1-D 如果标量或者矩阵,勾与不勾都一样。 如果是向量,勾选则表…

AUTOSAR从入门到精通-通信管理模块(CanNm)(七)

目录 原理 CanNM User Data CanNm user data配置 CDD方式访问CanNm user data ASW方式访问CanNm user data

Hago 的 Spark on ACK 实践

作者:华相 Hago 于 2018 年 4 月上线,是欢聚集团旗下的一款多人互动社交明星产品。Hago 融合优质的匹配能力和多样化的垂类场景,提供互动游戏、多人语音、视频直播、 3D 虚拟形象互动等多种社交玩法,致力于为用户打造高效、多样、…

2024华为OD机试真题指南宝典—持续更新(JAVAPythonC++JS)【彻底搞懂算法和数据结构—算法之翼】

PC端可直接搜索关键词 快捷键:CtrlF 年份关键字、题目关键字等等 注意看本文目录-快速了解本专栏 文章目录 🐱2024年华为OD机试真题(马上更新)🐹2023年华为OD机试真题(更新中)🐶新…

springCould中的consul-从小白开始【4】

目录 1.consul介绍 ❤️❤️❤️ 2.安装 ❤️❤️❤️ 3.创建8006模块 ❤️❤️❤️ 4.创建80模块❤️❤️❤️ 1.consul介绍 ❤️❤️❤️ Consul 是一种用于服务发现、配置和分布式一致性的开源软件。它由HashiCorp开发和维护,可用于帮助构建和管理现代化的分布…

设计模式篇---职责链模式

文章目录 概念结构实例总结 概念 职责链模式:避免将一个请求的发送者与接收者耦合在一起,让多个对象都有机会处理请求。将接收请求的对象连接成一条链,并且沿着这条链传递请求,直到有一个对象能够处理它为止。 比如大学期间&…

【MybatisPlus快速入门】(2)SpringBoot整合MybatisPlus 之 标准数据层开发 代码示例

目录 1 标准CRUD使用2 新增3 删除4 修改5 根据ID查询6 查询所有7 MyBatis-Plus CRUD总结 之前我们已学习MyBatisPlus在代码示例与MyBatisPlus的简介,在这一节中我们重点学习的是数据层标准的CRUD(增删改查)的实现与分页功能。代码比较多,我们一个个来学习…

05_符号表

05_符号表 一、符号表符号表API设计符号表实现有序符号表 一、符号表 符号表最主要的目的就是将一个键和一个值联系起来,符号表能够将存储的数据元素是一个键和一个值共同组成的键值对数据,我们可以根据键来查找对应的值。符号表中,键具有唯…

【Java基础】为什么重写equals()方法一定要重写hashCode()方法

equals()方法:比较两个对象是否相同。 1)用 号比较两个对象的内存地址,如果两个对象指向的是同一个内存地址,返回true。 2)否则继续比较字符串的值,如果值相同,返回true。 hashCode()方法&…

prometheus二进制安装

1、在需要安装prometheus的目录下执行wget命令下载软件到本地,如我的路径是/opt/module/prometheus wget https://github.com/prometheus/prometheus/releases/download/v2.34.0/prometheus-2.34.0.linux-amd64.tar.gz正在解析主机 objects.githubusercontent.com …

Qt/QML编程学习之心得:QML和C++的相互调用(十五)

Qt下的QML说到底是类似于JavaScript的一种解释性语言,习惯了VC的MVC(Veiw+Control)的模式,那种界面视图任何事件都是和C++的cpp中处理函数一一对应,在类中也有明确的说明的。一下子玩Qt会觉得哪里对不上,比如使用QML这种节脚本语言贴了图做了layout布局,那么一个按钮的o…

4.svn版本管理工具使用

1. 什么是SVN 版本控制 它可以记录每一次文件和目录的修改情况,这样就可以借此将数据恢复到以前的版本,并可以查看数据的更改细节! Subversion(简称SVN)是一个自由开源的版本控制系统。在Subversion管理下,文件和目录可以超越时空 SVN的优势 统一的版本号 Subversi…

婚庆婚礼策划服务网站建设的效果如何

品牌效应越来越重要,婚庆行业在多年的发展下,部分区域内也跑出了头部品牌,连锁门店也开了很多家,无论新品牌还是老品牌在新的区域开店总归少不了线上线下的宣传,虽然几乎每个人都会接触婚庆服务,但因为市场…

hadoop02_HDFS的API操作

HDFS的API操作 1 HDFS 核心类简介 Configuration类:处理HDFS配置的核心类。 FileSystem类:处理HDFS文件相关操作的核心类,包括对文件夹或文件的创建,删除,查看状态,复制,从本地挪动到HDFS文件系统中等。…

【什么是反射机制?为什么反射慢?】

✅ 什么是反射机制?为什么反射慢? ✅典型解析✅拓展知识仓✅反射常见的应用场景✅反射和Class的关系 ✅典型解析 反射机制指的是程序在运行时能够获取自身的信息。在iava中,只要给定类的名字,那么就可以通过反射机制来获得类的所有…