当前位置: 首页 > news >正文

【计算机网络笔记】路由算法之层次路由

系列文章目录

什么是计算机网络?
什么是网络协议?
计算机网络的结构
数据交换之电路交换
数据交换之报文交换和分组交换
分组交换 vs 电路交换
计算机网络性能(1)——速率、带宽、延迟
计算机网络性能(2)——时延带宽积、丢包率、吞吐量/率
计算机网络体系结构概念
OSI参考模型基本概念
OSI参考模型中非端-端层(物理层、数据链路层、网络层)功能介绍
OSI参考模型中端-端层(传输层、会话层、表示层、应用层)功能介绍
TCP/IP参考模型基本概念,包括五层参考模型
网络应用的体系结构
网络应用进程通信
网络应用对传输服务的需求
Web应用之HTTP协议(涉及HTTP连接类型和HTTP消息格式)
Cookie技术
Web缓存/代理服务器技术
传输层服务概述、传输层 vs. 网络层
传输层——多路复用和多路分用
传输层——UDP简介
传输层——可靠数据传输原理之Rdt协议
传输层——可靠数据传输之流水线机制与滑动窗口协议
传输层——TCP特点与段结构
传输层——TCP的可靠数据传输
TCP连接管理(图解三次握手和四次挥手)
传输层——拥塞控制原理与解决方法
TCP的拥塞控制机制
网络层服务与核心功能
网络层服务模型——虚电路网络
网络层服务模型——数据报网络
Internet网络的网络层——IP协议之IP数据报的结构
IP分片
IP编址与有类IP地址
IP子网划分与子网掩码
CIDR与路由聚合
DHCP协议
网络地址转换(NAT)
ICMP(互联网控制报文协议)
IPv6简介
路由算法之链路状态路由算法
路由算法之距离向量路由算法


  • 系列文章目录
  • 层次路由
  • 自治系统间(Inter-AS)路由任务


层次路由

更准确地说,它是一种路由策略。

链路状态路由算法和距离向量路由算法都需要将任意规模网络抽象为一个图再计算路由。若一个网络的规模特别大,那么这种抽象就会过于理想。

  • 从网络规模的角度考虑,如果有6亿目的结点的网络,那么路由表几乎无法存储,并且路由计算过程的信息 (e.g. 链路状态分组、 DV)交换量巨大,会淹没链路
  • 还需要考虑网络管理自治性的问题

层次路由就是把大规模网络再抽象一层,将一个区域内的路由器聚合在一起,称为自治系统AS (autonomous systems)。

  • 同一AS内的路由器运行相同的路由协议(算法),即自治系统内部路由协议 (“intra-AS” routing protocol)。不同自治系统内的路由器可以运行不同的AS内部路由协议
  • 每一个自制系统(AS)都有一个或多个特殊的路由器,叫网关路由器(gateway router),它位于AS“边缘”,通过链路连接其他AS的网关路由器。所以可以通过网关路由器与其它AS交换路由信息

因此,就可以把路由分为自治系统内的路由和自治系统间在这里插入图片描述
的路由。

自治系统间(Inter-AS)路由任务

在这里插入图片描述

假设AS1内某路由器收到一个目的地址在AS1 之外的数据报。那么路由器应该将该数据报转发给哪个网关路由器呢?为了解决这样的路由问题,AS1必须:

  • 学习到哪些目的网络可以通过AS2到达,哪些可以通过AS3到达
  • 将这些网络可达性信息传播给AS1内部路由器

以路由器1d为例,看看它的转发表设置。

  • 假设AS1学习到(通过AS间路由协议):子网x可以通过AS3 (网关 1c)到达,但不能通过AS2到达。这样的信息会被告知AS1中的所有路由器
    • 路由器1d:利用AS内部路由信息,确定其到达1c 的最小费用路径接口l,然后在转发表中增加入口:(x, I)
  • 假设AS1通过AS间路由协议学习到:子网x通过 AS3和AS2均可到达
    • 为了配置转发表,路由器1d必须确定应该将去往子网x的数据报转发给哪个网关。这个任务也是由AS间路由协议完成,去在多个网关中进行选择
    • 怎么选择?会用到热土豆路由,也就是将分组发送给最近的网关路由器

整个过程概括如下:

在这里插入图片描述

相关文章:

【计算机网络笔记】路由算法之层次路由

系列文章目录 什么是计算机网络? 什么是网络协议? 计算机网络的结构 数据交换之电路交换 数据交换之报文交换和分组交换 分组交换 vs 电路交换 计算机网络性能(1)——速率、带宽、延迟 计算机网络性能(2)…...

【华为OD机试python】分糖果【2023 B卷|100分】

【华为OD机试】-真题 !!点这里!! 【华为OD机试】真题考点分类 !!点这里 !! 题目描述 小明从糖果盒中随意抓一把糖果,每次小明会取出一半的糖果分给同学们。 当糖果不能平均分配时,小明可以选择从糖果盒中(假设盒中糖果足够) 取出一个糖果或放回一个糖果。 小明最少需要多…...

ARM 汇编基础

我们在学习 STM32 的时候几乎没有用到过汇编,可能在学习 UCOS 、 FreeRTOS 等 RTOS 类操作系统移植的时候可能会接触到一点汇编。但是我们在进行嵌入式 Linux 开发的时候是绝 对要掌握基本的 ARM 汇编,因为 Cortex-A 芯片一上电 SP 指针还…...

虹科Pico汽车示波器 | 汽车免拆检修 | 2017款东风本田XR-V车转向助力左右不一致

一、故障现象 一辆2017款东风本田XR-V车,搭载R18ZA发动机,累计行驶里程约为4万km。车主反映,车辆行驶或静止时,向右侧转向比向左侧转向沉重。 二、故障诊断 接车后试车,起动发动机,组合仪表上无故障灯点亮&…...

阿里云服务器ECS经济型e实例优惠99元性能怎么样?

阿里云服务器ECS经济型e实例优惠99元性能怎么样?阿里云服务器优惠99元一年,配置为云服务器ECS经济型e实例,2核2G配置、3M固定带宽和40G ESSD Entry系统盘,CPU采用Intel Xeon Platinum架构处理器,2.5 GHz主频&#xff0…...

vue3引入vuex基础

一:前言 使用 vuex 可以方便我们对数据的统一化管理,便于各组件间数据的传递,定义一个全局对象,在多组件之间进行维护更新。因此,vuex 是在项目开发中很重要的一个部分。接下来让我们一起来看看如何使用 vuex 吧&#…...

C++二维数组中的查找

4. 二维数组中的查找 题目链接 牛客网 题目描述 给定一个二维数组,其每一行从左到右递增排序,从上到下也是递增排序。给定一个数,判断这个数是否在该二维数组中。 Consider the following matrix: [[1, 4, 7, 11, 15],[2, 5, 8, 12, 19],[3, 6, 9, 16, 22],[1…...

【计算思维】蓝桥杯STEMA 科技素养考试真题及解析 2

1、兰兰有一些数字卡片,从 1 到 100 的数字都有,她拿出几张数字卡片按照一定顺序摆放。想一想,第 5 张卡片应该是 A、11 B、12 C、13 D、14 答案:C 2、按照下图的规律,阴影部分应该填 A、 B、 C、 D、 答案&am…...

Qt+sqlite3使用事务提升插入效率

参考&#xff1a; 【精选】SQLite批量插入效率_sqlite 批量插入_PengX_Seek的博客-CSDN博客 (1)不使用事务时&#xff1a; clock_t t_start clock();QSqlQuery query(db);QString sql("insert into test(col1,col2) values(1,2);");for (int i 0; i < 1000; i…...

【深度学习】不用Conda在PP飞桨Al Studio三个步骤安装永久PyTorch环境

在 PaddlePaddle AI Studio 中使用 Python 虚拟环境安装 PyTorch 免责声明 在阅读和实践本文提供的内容之前&#xff0c;请注意以下免责声明&#xff1a; 侵权问题: 本文提供的信息仅供学习参考&#xff0c;不用做任何商业用途&#xff0c;如造成侵权&#xff0c;请私信我&am…...

SpringBoot:kaptcha生成验证码

GitHub项目地址&#xff1a;GitHub - penggle/kaptcha: kaptcha - A kaptcha generation engine. kaptcha介绍 kaptcha官网&#xff08;Google Code Archive - Long-term storage for Google Code Project Hosting.&#xff09;对其介绍如下&#xff0c; kaptcha十分易于安装…...

C/C++ 使用API实现数据压缩与解压缩

在Windows编程中&#xff0c;经常会遇到需要对数据进行压缩和解压缩的情况&#xff0c;数据压缩是一种常见的优化手段&#xff0c;能够减小数据的存储空间并提高传输效率。Windows提供了这些API函数&#xff0c;本文将深入探讨使用Windows API进行数据压缩与解压缩的过程&#…...

Visual Studio连接unity编辑器_unity基础开发教程

Visual Studio连接unity编辑器 问题描述解决方法意外情况 问题描述 当我们在unity编辑器中打开C#脚本的时候发现Visual Studio没有连接unity编辑器&#xff0c;在编写代码的时候也没有unity关键字的提醒。 简单来说就是敲代码没有代码提示。 解决方法 这时候需要在unity中进行…...

2023亚太杯数学建模B题思路分析 - 玻璃温室中的微气候法规

1 赛题 问题B 玻璃温室中的微气候法规 温室作物的产量受到各种气候因素的影响&#xff0c;包括温度、湿度和风速[1]。其中&#xff0c;适 宜的温度和风速是植物生长[2]的关键。为了调节玻璃温室内的温度、风速等气候因素 , 温室的设计通常采用带有温室风扇的通风系统&#xf…...

轻量封装WebGPU渲染系统示例<37>- 多个局部点光源应用于非金属材质形成的效果(源码)

当前示例源码github地址: https://github.com/vilyLei/voxwebgpu/blob/feature/rendering/src/voxgpu/sample/BasePbrMaterialMultiLights.ts 当前示例运行效果: 此示例基于此渲染系统实现&#xff0c;当前示例TypeScript源码如下&#xff1a; export class BasePbrMaterial…...

设备状态监测与故障诊断系统的作用

随着工业生产的发展和技术的进步&#xff0c;设备状态监测与故障诊断系统在工业领域中扮演着越来越重要的角色。这一系统通过实时监测设备的状态和参数&#xff0c;及时发现潜在的故障&#xff0c;并提供预警信号&#xff0c;以降低生产中断、提高安全性和维护效率。以下将详细…...

浮点数运算精度丢失,如何解决

为什么浮点数运算的时候会有精度丢失的风险&#xff1f; 浮点数运算精度丢失代码演示&#xff1a; float a 2.0f - 1.9f; float b 1.8f - 1.7f; System.out.println(a);// 0.100000024 System.out.println(b);// 0.099999905 System.out.println(a b);// false为什么会出现…...

使用微信小程序openMapApp接口,报错问题解决openMapApp:fail invaild coord

使用微信小程序的 openMapApp 接口时遇到了坐标无效的错误 (openMapApp:fail invalid coord)。这个错误通常是由于提供的地理坐标不符合预期的格式或范围而引起的&#xff1a; 坐标格式&#xff1a; 确保提供的坐标符合正确的格式。常见的格式是 "纬度,经度"&#xf…...

2023亚太杯数学建模思路 - 案例:粒子群算法

文章目录 1 什么是粒子群算法&#xff1f;2 举个例子3 还是一个例子算法流程算法实现建模资料 # 0 赛题思路 &#xff08;赛题出来以后第一时间在CSDN分享&#xff09; https://blog.csdn.net/dc_sinor?typeblog 1 什么是粒子群算法&#xff1f; 粒子群算法&#xff08;Pa…...

【开源】基于JAVA的开放实验室管理系统

项目编号&#xff1a; S 013 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S013&#xff0c;文末获取源码。} 项目编号&#xff1a;S013&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、研究内容2.1 实验室类型模块2.2 实验室模块2.3 实…...

10分钟高效掌握SMU调试工具:AMD Ryzen处理器配置优化实战指南

10分钟高效掌握SMU调试工具&#xff1a;AMD Ryzen处理器配置优化实战指南 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: htt…...

GUI自动化测试中的显式坐标映射技术解析

1. 项目背景与核心挑战在自动化测试和机器人操作领域&#xff0c;GUI元素的精确定位一直是个令人头疼的问题。传统基于图像识别的定位方式就像用一把刻度模糊的尺子测量物体——当屏幕分辨率、缩放比例或主题样式发生变化时&#xff0c;定位精度就会像沙漏里的沙子一样不断流失…...

axios 的 GET 请求里,手动写 Content-Type: application/json 基本都会被删掉不是你写法错了是 axios 源码故意这么做的

一、为什么 GET 的 Content-Type 会被删掉看 axios 源码&#xff08;xhr.js&#xff09;里的逻辑&#xff1a;if (typeof requestData undefined && key.toLowerCase() content-type) {// Remove Content-Type if data is undefineddelete requestHeaders[key]; }GET…...

HCIP Datacom实验指南:亲手搭一个VLAN聚合网络,搞懂Super-VLAN和Sub-VLAN的通信全过程

HCIP Datacom实验指南&#xff1a;从零构建VLAN聚合网络并深度解析通信机制 在当今企业网络架构中&#xff0c;IP地址资源的高效利用和广播域的有效隔离是网络工程师面临的两大核心挑战。VLAN聚合技术&#xff08;Super-VLAN与Sub-VLAN&#xff09;通过巧妙的逻辑分层设计&…...

告别手动复制粘贴:用J-Link Commander+BAT脚本实现芯片ID的自动化读取与记录

嵌入式产线自动化&#xff1a;基于J-Link Commander的芯片ID批量采集方案 在工业4.0时代&#xff0c;嵌入式设备生产线的自动化程度直接影响着企业的核心竞争力。想象这样一个场景&#xff1a;每天有上万块电路板需要完成最终测试&#xff0c;每块板子都需要准确记录其核心芯片…...

基于树莓派Pico与TinyML的鸟类鸣叫识别物联网终端全栈开发指南

1. 项目概述与核心价值最近在折腾一个挺有意思的物联网项目&#xff0c;叫“BirdWeather-PUC”。这个名字乍一看有点专业&#xff0c;拆开来看&#xff0c;“BirdWeather”直译是“鸟类天气”&#xff0c;而“PUC”在项目语境里通常指“Processing Unit Controller”&#xff0…...

Tidyverse 2.0正式版深度适配手册:从CRAN安装到PDF/HTML自动发布(含内部调试钩子清单)

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;Tidyverse 2.0正式版核心演进与自动化报告范式转型 Tidyverse 2.0 不再是模块的松散集合&#xff0c;而是一个语义一致、生命周期协同演进的统一生态系统。其核心突破在于引入 lifecycle 驱动的 API 稳…...

Blender 3MF插件终极指南:让3D打印文件转换变得简单快速

Blender 3MF插件终极指南&#xff1a;让3D打印文件转换变得简单快速 【免费下载链接】Blender3mfFormat Blender add-on to import/export 3MF files 项目地址: https://gitcode.com/gh_mirrors/bl/Blender3mfFormat 还在为3D打印文件格式转换而烦恼吗&#xff1f;Blend…...

终极指南:3分钟实现Adobe Illustrator到Photoshop的无损图层转换

终极指南&#xff1a;3分钟实现Adobe Illustrator到Photoshop的无损图层转换 【免费下载链接】ai-to-psd A script for prepare export of vector objects from Adobe Illustrator to Photoshop 项目地址: https://gitcode.com/gh_mirrors/ai/ai-to-psd 还在为AI文件转P…...

TEE安全开发避坑指南:细数TEE OS API那些容易用错的函数(以GlobalPlatform规范为据)

TEE安全开发避坑指南&#xff1a;细数TEE OS API那些容易用错的函数 在TEE&#xff08;可信执行环境&#xff09;开发中&#xff0c;GlobalPlatform&#xff08;GP&#xff09;规范定义的API是开发者构建安全可信应用&#xff08;TA&#xff09;的基础工具集。然而&#xff0c;…...