计算机网络:网络层 - 路由选择协议
计算机网络:网络层 - 路由选择协议
- 路由器的结构
- 路由选择协议概述
- 自治系统 AS
- 内部网关协议
- 路由信息协议 RIP
- 距离向量算法
- RIP报文格式
- 收敛问题
- 开放最短路径优先 OSPF
- 基本工作原理
- 自治系统分区
- 外部网关协议
- BGP-4
路由器的结构
如图所示,路由器被分为路由选择
与分组转发
两个部分:
在分组转发
中:
当一个数据报从端口进入,要依次被物理层
,数据链路层
,网络层
层层解析,得到数据报。随后根据转发表
,决定从哪一个端口传出,再依次被网络层
,数据链路层
,网络层
层层封装。
转发的核心就是这个转发表
,而转发表
是由路由选择
的路由表
得出的!
路由器通过路由选择协议
来构建路由表
,从而得出转发表
,才能合理转发数据报。本博客就讲解路由选择协议
,来了解路由表
是如何得出的。
路由选择协议概述
路由选择协议分为静态路由选择
和动态路由选择
。
静态路由选择
:由人工配置的路由,不能及时适应网络的变化,一般来说只在小规模网络中使用动态路由选择
:路由器自己获取路由信息,能够及时适应网络变化,一般大型网络使用
因特网作为全球最大的网络,毫无疑问要使用动态路由选择
,动态路由选择有以下特点:
自适应
:动态路由选择能较好适应网络状态变化分布式
:将一个系统或任务分解成多个部分,并将其分配到多个节点上执行,这些节点之间通过网络互相通信,最终协作完成整个任务。路由器之间就是这样完成任务的。分层次
:整个因特网被划分为很多自治系统
,按层次管理
接下来本博客就讲解这个动态路由选择
。
自治系统 AS
由于互联网的规模非常大,如果让所有的路由器知道所有的网络应怎样到达,则路由表将会非常大,处理起来花费的时间也会很多,所以互联网采用分层次的路由选择协议
。
该协议将互联网划分为许多个较小的自治系统 AS
,如下图:
每个
AS
对其它的AS
表现为一个单一的,一致的路由
比如上图中,左上角的AS
只通过R1
连接外部,所以该AS
内部的报文,都要通过R1
传输。
- 每个
AS
内部,使用内部网关协议
- 不同的
AS
之间,使用的是外部网关协议
如上图,自治系统 A
内部使用了内部网关协议RIP
,而自治系统 B
内部使用了内部网关协议OSFP
。也就是说,不同的AS
使用不同的内部网关协议,也可以进行通信。在两个AS
之间,使用了外部网关协议BGP-4
。
内部网关协议
路由信息协议 RIP
RIP
是一种基于距离向量
的路由选择协议
所谓距离向量,计算规则如下:
- 路由器到直连网络的距离为
1
- 路由器到非直连网络的距离,为经过的路由器数目加
1
如下图:
网络N1
与R1
直连,那么R1
到N1
的距离向量就是1
;而R3
与N2
并不直连,途径一个路由器R2
,那么距离向量就是路由器数目 + 1 = 2
。
距离向量
的最大值为15
,当大于等于16
时,表示不可达
,即不能通过该路由连接到对应的网络。
在RIP
路由表中,主要包含以下信息:
目的网络
:目的网络的地址距离
:到达该网络的距离向量下一跳路由
:到达该网络,要把数据报传输给哪一个路由
那么路由器如何构建自己的路由表呢?
- 路由器仅和
相邻路由器
交换信息 - 交换的信息为本路由器知道的
所有信息
- 路由器按照固定的时间间隔交换信息,然后根据
距离向量算法
更新自己的路由表
距离向量算法
当路由器接收到来自相邻路由器的RIP报文
,就要通过距离向量算法更新自己的路由表,规则如下:
- 收到报文后,先修改报文的内容,将
距离
字段加一,下一跳
字段变为发送该报文的路由器
如下图:
现在R2
给R1
发送了一个RIP报文
,内部包含到net2
的信息,其中:距离字段要+1
,表示R1
想要到达该网络,需要再经过R2
路由器;而下一跳
要变为R2
,表示到达该网络需要将数据报转发给R2
。
- 将修改后的数据报,与自己原先的路由表对比,更新路由表
- 如果原先路由表中没有目的网络,那么将该网络添加到自己的路由表中
- 如果原先路由表有相同的目的网络,那么根据以下规则更新:
- 如果报文中的
下一跳
的地址与原先下一跳
相同:那么更新路由表的距离
,这是因为网络随时都有可能变化,有可能同一个路由器到一个网络的距离变了,此时要用最新的,确保信息正确 - 如果报文中的
下一跳
的地址与原先下一跳
不相同:此时比较距离
,保留距离
比较小的那一条
- 如果报文中的
示例:
R1
收到了R2
发来的RIP报文
,修改后如右图。
net1
:原先R1
中没有对应的网络,将该条目添加到路由表中net2
:原先R1
有该网络,并且下一跳
同为R2
,此时就算距离
变长了,也要更新报文,距离从3
变为8
net3
:原先R1
有该网络,但是下一跳
不相同,此时比较距离11 > 8
,说明R2
比R3
距离短,选用R2
,更新路由net4
:原先R1
有该网络,但是下一跳
不相同,此时比较距离3 < 6
,说明R4
比R2
距离短,选用R4
,不更新路由
最后R1
路由表变为:
另外的:如果三分钟没有收到相邻路由器的RIP报文
,则把该路由器记为不可达,把距离设置为16
RIP报文格式
RIP报文
格式如下:
如图所示,RIP报文
被封装在UDP数据报
后,在被封装进了IP数据报
,其实RIP
本质是一个应用层协议。
在RIP
的路由部分
中,包含了最重要的网络(网络地址+子网掩码)
,下一跳
,距离
这三个字段。一个报文中最多包含25
个这样的路由信息。
收敛问题
RIP
协议的优点是实现非常简单,开销很小。
但是RIP
也有不少缺点:
- 限制了自治系统的大小:
RIP
限制最大距离为16
,这也决定了使用RIP
的自治系统不能太大 - 收敛时间长:也叫做”坏消息传播慢“
收敛
:自治系统中所有节点都得到正确的路由信息的过程
接下来我们就看看为什么存在收敛时间长
的问题:
现在R1
直连网络net1
,R2
通过R1
间接连接到net1
,突然R1
断开了与net1
的连接,此时把距离改为16
:
当R1
还没来得及告诉R2
自己的路由表,R2
就给R1
发送了RIP报文
:
此时R1
误以为可以通过R2
连接到net1
,于是更新自己的路由表:
此时就已经产生了错误信息了,过一会R1
又给R2
发送RIP报文
:
此时R2
以为R1
的链路变长了,于是把自己的距离更新为4
,随后R2
给R1
发送报文:
此时R1
再更新,以此类推,直到两边距离都为16
:
此时路由器R1
和R2
才直到,net1
是不可达的。这就是为什么RIP
的收敛速度慢。
开放最短路径优先 OSPF
开放最短路径优先OSPF
,是为了克服RIP
的缺点而开发出来的。
开放
:表明OSPF
不是受公司控制的,而是公开发表的协议最短路径优先
:使用了最短路径算法SFP
先前的
RIP
是基于距离
的协议,而OSPF
是基于链路状态
的,路由器会维护一个整个网络的拓扑图,并基于此图计算最优路径
OSFP
不会限制网络的规模,而且收敛速度快。
基本工作原理
OSPF
需要先建立和维护邻居关系
,这个过程是通过问候分组 hello
实现的:
如图所示,每个路由器都有自己的邻居表
,R1
的邻居就是R2
和R4
。每隔十秒钟,路由器就会发送一次hello 分组
,如果连续40
秒没有收到对应的hello 分组
,那么认为该路由器不可达。
路由器会通过数据交换,让每个路由器都由一个
链路状态数据库 LSDB
,并基于这个数据库,计算出自己到达各个路由器的最短路径,从而构建效率最高的路由表。
数据交换过程通过五种分组维护:
问候分组
:用来构建和维护邻居路由
数据库描述分组
:向邻居路由给出自己的链路状态数据库的摘要信息链路状态请求分组
:向邻居路由请求更加详细的信息链路状态更新分组
:将自己的详细信息发送出去,通过泛洪法,让自治系统的所有路由器都可以更新状态链路状态确认分组
:当路由器通过链路状态更新分组
,更新了自己的数据库后,通过该报文确认
如图所示,一开始路由器之间交换问候分组,维护邻居关系:
当满足一定条件,路由器R1
发送自己的数据库描述分组
:
在数据库描述分组
中,记录了R1
的数据库的概括信息。如果R2
检查数据库描述分组
后发现,有一些信息自己没有,或者不太一样,就向R1
发出链路状态请求分组
,以获取更加详细的信息:
当R1
收到链路状态请求分组
后,通过泛洪法向所有路由器发送链路状态更新分组
,==该分组详细描述了R1
自己的数据库,其他路由器就可以根据这个分组更新自己的数据库,以获取最新的信息。==收到链路状态更新分组
的路由器,还要往回发送链路状态确认分组
,对之前的分组确认。
自治系统分区
?为了使OSFP
可以作用与规模很大的网络,OSFP
会把一个自治系统划分为若干个更小的范围,叫做区域
每个自治系统都包含一个主干区域
,其它区域都通过主干区域
连接自治系统外部。
每个区域都有自己的标识符,该编号为32
位,以点分十进制表示,主干区域的标识符固定为0.0.0.0
。每个区域都要通过一个区域边界路由器
来连接主干区域,比如上图中R3
,R4
,R7
都是区域边界路由器。
利用泛洪法交换链路状态信息时,是在每个区域之间,而非整个自治系统
这样就可以避免路由器太多,导致太多的链路状态信息被发送到网络中,导致网络拥挤了。
外部网关协议
BGP-4
由于不同的自治系统使用不同的内部路由选择协议并使用不同的度量,所以必须在不同的自治系统之间使用另外的路由选择协议。目前使用最多的是边界网关协议 BGP
, 其最新版本是 BGP-4
)。
BGP
只能是力求寻找一条能够到达目的网络且比较好的路由,而并非要寻找一条最佳路由。
本博客不详细讲解BGP-4
协议,只是简单的讲解其作用。
相关文章:
计算机网络:网络层 - 路由选择协议
计算机网络:网络层 - 路由选择协议 路由器的结构路由选择协议概述自治系统 AS内部网关协议路由信息协议 RIP距离向量算法RIP报文格式收敛问题 开放最短路径优先 OSPF基本工作原理自治系统分区 外部网关协议BGP-4 路由器的结构 如图所示,路由器被分为路由…...
JupyterLab使用指南(六):JupyterLab的 Widget 控件
1. 什么是 Widget 控件 JupyterLab 中的 Widget 控件是一种交互式的小部件,可以用于创建动态的、响应用户输入的界面。通过使用 ipywidgets 库,用户可以在 Jupyter notebook 中创建滑块、按钮、文本框、选择器等控件,从而实现数据的交互式展…...
OpenCV 特征点检测与匹配
一 OpenCV特征场景 ①图像搜索,如以图搜图; ②拼图游戏; ③图像拼接,将两长有关联得图拼接到一起; 1 拼图方法 寻找特征 特征是唯一的 可追踪的 能比较的 二 角点 在特征中最重要的是角点 灰度剃度的最大值对应的…...
css布局之flex应用
/*父 100*/.parent-div {/* 这里添加你想要的属性 */display: flex;flex-direction: row; //行justify-content: space-between; //左右对齐align-items: center;flex-wrap: wrap; //换行}/*中 90 10 */.middle-div {/* 这里添加你想要的属性 */display: flex;flex-direction:…...
树莓派4B设置AP热点步骤
树莓派4B设置AP热点步骤:先进入root模式 预先进行apt-get update 第1步:安装network-manager sudo apt-get install network-manager第2步:安装git apt-get install git apt-get install util-linux procps hostapd iproute2 iw haveged …...
Java程序之百鸡百钱问题
题目: 百钱买百鸡的问题算是一套非常经典的不定方程的问题,题目很简单:公鸡5文钱一只,母鸡3文钱一只,小鸡3只一文钱,用100文钱买一百只鸡,其中公鸡,母鸡,小鸡都必须要有,…...
Mybatis——动态sql
if标签 用于判断条件是否成立。使用test属性进行条件判断,如果条件为true,则拼接sql。 <where>标签用于识别语句是否需要连接词and,识别sql语句。 package com.t0.maybatisc.mapper;import com.t0.maybatisc.pojo.Emp; import org.a…...
可视化大屏开发系列——页面布局
页面布局是可视化大屏的基础,想要拥有一个基本美观的大屏,就得考虑页面整体模块的宽高自适应,我们自然就会想到具有强大灵活性flex布局,再借助百分比布局来辅助。至此,大屏页面布局问题即可得到解决。 可视化大屏开发系…...
Python statistics 模块
Python 的 statistics 模块提供了一组用于执行各种统计计算的函数,包括平均值、中位数、标准差、方差以及其他统计量。让我来简单介绍一下。 首先,你可以使用以下方式导入 statistics 模块: python import statistics 接下来,…...
wireshark常见使用表达式
目录 1. 捕获过滤器 (Capture Filters)基本捕获过滤器组合捕获过滤器 2. 显示过滤器 (Display Filters)基本显示过滤器复杂显示过滤器协议特定显示过滤器 3. 进阶显示过滤器技巧使用函数和操作符逻辑操作符 4. 常见网络协议过滤表达式示例HTTP 协议HTTPS 协议DNS 协议DHCP 协议…...
用Java获取键盘输入数的个十百位数
这段Java代码是一个简单的程序,用于接收用户输入的一个三位数,并将其分解为个位、十位和百位数字,然后分别打印出来。下面是代码的详细解释: 导入所需类库: import java.util.Scanner;:导入Scanner类,用于从…...
第10章 启动过程组 (制定项目章程)
第10章 启动过程组 9.1制定项目章程,在第三版教材第356~360页; 文字图片音频方式 视频12 第一个知识点:主要输出 1、项目章程(重要知识点) 项目目的 为了稳定与发展公司的客户群(抽象,非具体) 可测量的项目…...
html侧导航栏客服栏
ico 替换 ICO <html xmlns"http://www.w3.org/1999/xhtml"><head><meta http-equiv"Content-Type" content"text/html; charsetutf-8"><title>返回顶部</title><script src"js/jquery-2.0.3.min.js"…...
Clonable接口和拷贝
Hello~小伙伴们!本篇学习Clonable接口与深拷贝,一起往下看吧~(画图水平有限,两张图,,我真的画了巨久,求路过的朋友来个3连~阿阿阿~~~) 目录 1、Clonable接口概念 2、拷贝 2、1浅拷贝 2、2深拷贝 1、Clon…...
关于小蛋の编程和小蛋编程为同一作者的说明
小蛋の编程和小蛋编程的作品为同一人制作,因前者为父母的手机号进行注册,现用本人手机号注册了新账号小蛋编程,后续文章将在新账号小蛋编程上进行刊登,同时在小蛋编程上对原账号文章进行转载。此账号不再发布帖子,请大…...
大数据平台之Spark
Apache Spark 是一个开源的分布式计算系统,主要用于大规模数据处理和分析。它由UC Berkeley AMPLab开发,并由Apache Software Foundation维护。Spark旨在提供比Hadoop MapReduce更快的处理速度和更丰富的功能,特别是在处理迭代算法和交互式数…...
How to use ModelSim
How to use ModelSim These are all written by a robot Remember, you can only simulate tb files....
【专业英语 复习】第8章 Communications and Networks
1. 单选题 One of the most dramatic changes in connectivity and communications in the past few years has been ____. A. widespread use of mobile devices with wireless Internet connectivity B. chat rooms C. satellite uplinks D. running programs on rem…...
运行vue3项目相关报错
1. VSCode打开TSVue3项目很多地方报错 报错内容 几乎所有文件都会出现未知飘红 error Delete CR prettier/prettier报错原因 插件冲突,Windows系统回车换行符与MAC不一致(所以这个问题Windows系统才会出现) 解决 需要安装Vue - Official…...
2024年6月计算机视觉论文推荐:扩散模型、视觉语言模型、视频生成等
6月还有一周就要结束了,我们今天来总结2024年6月上半月发表的最重要的论文,重点介绍了计算机视觉领域的最新研究和进展。 Diffusion Models 1、Autoregressive Model Beats Diffusion: Llama for Scalable Image Generation LlamaGen,是一个…...
Centos Stream9 和Centos Stream10的下载网址
Index of /https://mirror.stream.centos.org/...
chrome 录制器及性能分析工具的使用
需求背景: 对比不同VPN方案网络延迟的差异。 验证工具: chrome浏览器自带的录制器、性能插件可以完美的解决这个问题。 注意:录制的操作都在当前页面,不存在新开标签页的场景 解决方案: 使用chrome录制器…...
如何打造稳定、好用的 Android LayoutInspector?
速度极慢,遇到复杂的布局经常超时 某些情况无法选中指定的 View 本文将围绕 LayoutInspector 的痛点,分析问题并修复,最终将 LayoutInspector 变成一个稳定、好用的插件。 二、加速 Dump View Hierarchy 2.1 问题描述 开发复杂业务的同学…...
C++ Thead互斥量死锁,mutex如何防止死锁---C++11多线程快速学习
假设有两个线程 T1 和 T2,它们需要对两个互斥量 mtx1 和 mtx2 进行访问,而且需要按照以下顺序获取互斥量的所有权: - T1 先获取 mtx1 的所有权,再获取 mtx2 的所有权。 - T2 先获取 mtx2 的所有权,再获取 mtx1 的所有…...
Ubuntu 之Glade图形化设计器
演示环境说明:本机使用Windows 11 家庭版本搭载 Ubuntu 22.04.4 LTS 子系统,同时并安装Ubuntu桌面虚拟化软件XLaunch。 如果没有搭建好上述问题,请参考:windows11子系统Ubuntu 22.04.4子安装图形化界面 Glade是什么?…...
152. 乘积最大子数组
152. 乘积最大子数组 题目链接:152. 乘积最大子数组 代码如下: class Solution { public:int maxProduct(vector<int>& nums) {int resnums[0];vector<int> f(nums.size()1,0),g(nums.size()1,0);f[0]nums[0],g[0]nums[0];for(int i1…...
proactor模式
Proactor模式是一种异步I/O的设计模式,它允许程序直接发起一个异步I/O操作并立即返回,而不需要等待该操作完成。一旦I/O操作实际完成,系统会通知相应的完成处理程序(Completion Handler),该处理程序随后执行…...
Charles抓包工具
一、charles简介 1,charles是什么 Charles中文名叫青花瓷,它是一款基于HTTP协议的代理服务器,通过成为电脑或者浏览器的代理,然后截取请求和请求结果达到分析抓包的目的。 特点:跨平台、半免费 2,charles工作原理 前…...
RabbitMQ如何保证消息可靠
解决办法: 1、做好消息确认机制(pulisher、consumer[手动ACK]) 2、每一个发送的消息都在数据库做好记录。定期将失败的消息再次发送一遍 消息确认机制: 生产者确认模式:确认消息是否发送到broker,失败…...
学习笔记——路由网络基础——路由的高级特性
七、路由的高级特性 1、路由迭代(路由递归) 路由必须有直连的下一跳才能够指导转发,静态路由或BGP路由的下一跳可能不是直连的邻居,因此需要计算出一个直连的下一跳和对应的出接口,这个过程就叫做路由迭代(路由递归)。 添加一条去往20.1.1.…...
html5 网站开发/潍坊今日头条新闻
Touch’n Go eWallet 面临APP测试挑战 Touch’n Go eWallet (以下简称 TNG eWallet)是马来西亚第一大电子钱包,目前已拥有超过1850万注册用户。作为马来西亚国民级金融类移动应用,任何App质量与体验问题都可能对C端用户造成严重影…...
网站建设百度百科/网络营销的概念及内容
函数rust中的函数函数方法闭包捕获作为输入参数类型匿名输入函数作为输出参数rust标准库中的示例Iterator::anyIterator::find高阶函数发散函数rust中的函数 函数 函数的声明使用关键字fn。函数的参数需要使用类型注释,就像变量一样。 如果函数有返回值࿰…...
成人高考报名时间2023年截止时间/百度seo服务公司
一个多线程应用程序中的线程彼此间可能关联也可能不关联。例如,在每个程序中都有一个用来生成其他子线程的主线程,所以主线程就成了所有其他线程的控制器。在一个多线程应用程序中有三种常用方法来定义线程间的关系: 1. 主线程和工作线程模型…...
怎么推广一个网站/百度移动
修改app1的路由 在views.py里面增加函数 在项目目录下面增加templates文件夹,并在其下面添加name.html文件 在项目配置文件里面的TEMPLATES里面修改DIRS配置如下 运行服务器,访问http://127.0.0.1:8000/app1/get_name得到name.html...
网络运营策划/长春seo按天计费
我在我的SQL上收到此错误:错误的MySQL说:文档无法连接:设置无效。 phpMyAdmin尝试连接到MySQL服务器,服务器拒绝连接。 您应该检查配置中的主机,用户名和密码,并确保它们与MySQL服务器管理员提供的信息相对…...
网站百度突然不收录了/google关键词分析
档案馆库房专用的一款智能型空气质量云测仪 空气质量检测仪 空气质量传感器 环境集成传感器 集成/温湿度、粉尘PM2.5 PM10/甲醛/TVOC/CO2等高度集成的一款传感器/RS485信号输出 ◆温度测量参数: (1)温度测量范围: -40~80℃(2)输出分辨率:0.1oC (3)…...