STP之算法详解笔记

2024-05-01 04:58
文章标签 算法 详解 笔记 stp

本文主要是介绍STP之算法详解笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

STP   Spanning-Tree Protocol,生成树协议,自动防环路必杀技,今天讲讲他的是怎么防环的。这里主要是讲怎么计算,至于BPDU之类的解释这里先不讲,先看图:


SW2连接SW1用的是F0/1,SW2链接SW4用的是F0/3,SW2链接SW3用的是F0/2,图有一些不清楚,见谅

假如这4台交换机只是傻瓜交换机,没有防环机制,那这个局域网里面就充满了广播风暴,这里解释一下广播风暴是怎么产生的。我举一个SW1里终端 ping SW3里终端(下面简称SW1和SW3)的例子:

如果这4太机器都是刚刚开机的,本地没有arp表,那SW1要去Ping SW2,第一个包就是ARP广播,广播有一个机制,就是不会从源端口再接收这个广播,那我画一个图,大家理解一下,看图


我这里不讨论正确的arp包怎么传,就看我这两种颜色的线围成的三角,他们满足广播不从源端口接收发出去的广播,但是他们就会再里面循环发送,由于二层设备没有TTL值,他们是不会自己被丢弃的,你乍一看,还好么,老子五六千一台的交换机,来两个环有啥?但是,如果你把4台设备都这么连上试试,广播指数增长,直接让你整个网络宕机。

但是组建网络的时候必然会考虑到备份链路的问题,物理链路的备份,肯定会环路,那怎么解决呢?

STP:简单的说就是逻辑上把一个接口暂时设置为block,防止环路的形成。

如图,这么多接口,交换机怎么知道哪个应该block?

这里开始讲今天的重点,STP算法:

第一步:选出根网桥----Root Bridge   (RB)

我的拓扑里有4太交换机,他们通过BPDU(知道就好,我这里不讨论)传递互相信息,然后选举。选举自然有标准

对比BID-----Bridge ID

BID=网桥优先级+网桥背板MAC

-先对比优先级,默认取值32768,越小越优先

-如果优先级相同对比背板MAC大小,越小越优先,我上面图标注了每一台设备的MAC

每台设备的MAC理论上是不一样的,所以就算优先级都是默认相同,通过MAC也能对比出谁是RB,自然我们可以通过手动修改优先级,去控制选举。



第二步,选举根端口-------Root Port (RP)

在每一台非根网桥里选择出到达根网桥(RB)唯一的最近端口,这里要分三步

1、到达根路径最小开销,这个是根据带宽来计算的,越小越优先

10M---------100

100M--------19

1000M-------4

10000M------2

2、如果开销相同,再对比直连网桥的BID,越小越优先

SW2的直连网桥就是SW3和SW4,因为根据上面选举RB的算法,SW1已经被选为RB。

这种时候也是会出现相同的情况,看图


两台SW之间都是100M带宽,假设上面那台SW是RB,那switch5的两个接口的直连网桥就是一样的。

3、对比直连网桥端口ID-------Port ID(PID),越小越优先

PID=端口优先级+端口编号

端口优先级默认128 取值1-255

端口编号就是端口的名字

PID举例:f0/1口 === 128.1

这样就算是上面那张图也能区分哪个是根端口了吧。




第三步,选举指定端口------Design Port(DP)

定义:每一条链路上都必须要有一个指定端口,且只能有一个!!!

STP内所有接口都必须要有一个角色,且只能有一个!!!

1、RB的所有接口都是指定端口

2、端口所在交换机,从该交换机的RP到RB开销最小。

DP是两台交换机之间的直连链路进行选举,不是一台交换机自己多个接口选举。

如果链路的两个接口其中有一个是RP,那另外一个必然是DP。

3、对比端口所在交换机的BID,越小越优先

p.s.我看的那份笔记里写着还有第4中比较,就是所在交换机PID比较,越小越优先,但是我没有想到一种拓扑,通过前三种比对之后,还选不出来的情况



经过以上所有计算以后,所有没有角色的端口都为阻塞端口。

这篇关于STP之算法详解笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

python利用backoff实现异常自动重试详解

《python利用backoff实现异常自动重试详解》backoff是一个用于实现重试机制的Python库,通过指数退避或其他策略自动重试失败的操作,下面小编就来和大家详细讲讲如何利用backoff实... 目录1. backoff 库简介2. on_exception 装饰器的原理2.1 核心逻辑2.2

QT6中绘制UI的两种方法详解与示例代码

《QT6中绘制UI的两种方法详解与示例代码》Qt6提供了两种主要的UI绘制技术:​​QML(QtMeta-ObjectLanguage)​​和​​C++Widgets​​,这两种技术各有优势,适用于不... 目录一、QML 技术详解1.1 QML 简介1.2 QML 的核心概念1.3 QML 示例:简单按钮

一文详解PostgreSQL复制参数

《一文详解PostgreSQL复制参数》PostgreSQL作为一款功能强大的开源关系型数据库,其复制功能对于构建高可用性系统至关重要,本文给大家详细介绍了PostgreSQL的复制参数,需要的朋友可... 目录一、复制参数基础概念二、核心复制参数深度解析1. max_wal_seChina编程nders:WAL

Nginx路由匹配规则及优先级详解

《Nginx路由匹配规则及优先级详解》Nginx作为一个高性能的Web服务器和反向代理服务器,广泛用于负载均衡、请求转发等场景,在配置Nginx时,路由匹配规则是非常重要的概念,本文将详细介绍Ngin... 目录引言一、 Nginx的路由匹配规则概述二、 Nginx的路由匹配规则类型2.1 精确匹配(=)2

一文详解如何查看本地MySQL的安装路径

《一文详解如何查看本地MySQL的安装路径》本地安装MySQL对于初学者或者开发人员来说是一项基础技能,但在安装过程中可能会遇到各种问题,:本文主要介绍如何查看本地MySQL安装路径的相关资料,需... 目录1. 如何查看本地mysql的安装路径1.1. 方法1:通过查询本地服务1.2. 方法2:通过MyS

Mysql数据库中数据的操作CRUD详解

《Mysql数据库中数据的操作CRUD详解》:本文主要介绍Mysql数据库中数据的操作(CRUD),详细描述对Mysql数据库中数据的操作(CRUD),包括插入、修改、删除数据,还有查询数据,包括... 目录一、插入数据(insert)1.插入数据的语法2.注意事项二、修改数据(update)1.语法2.有

SQL Server中的PIVOT与UNPIVOT用法具体示例详解

《SQLServer中的PIVOT与UNPIVOT用法具体示例详解》这篇文章主要给大家介绍了关于SQLServer中的PIVOT与UNPIVOT用法的具体示例,SQLServer中PIVOT和U... 目录引言一、PIVOT:将行转换为列核心作用语法结构实战示例二、UNPIVOT:将列编程转换为行核心作用语

Python logging模块使用示例详解

《Pythonlogging模块使用示例详解》Python的logging模块是一个灵活且强大的日志记录工具,广泛应用于应用程序的调试、运行监控和问题排查,下面给大家介绍Pythonlogging模... 目录一、为什么使用 logging 模块?二、核心组件三、日志级别四、基本使用步骤五、快速配置(bas

C#特性(Attributes)和反射(Reflection)详解

《C#特性(Attributes)和反射(Reflection)详解》:本文主要介绍C#特性(Attributes)和反射(Reflection),具有很好的参考价值,希望对大家有所帮助,如有错误... 目录特性特性的定义概念目的反射定义概念目的反射的主要功能包括使用反射的基本步骤特性和反射的关系总结特性

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.