理解STP(spanning-tree)生成树协议中各种端口的选举

2023-12-22 06:58

本文主要是介绍理解STP(spanning-tree)生成树协议中各种端口的选举,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 1、STP生成树协议简介
  • 2、STP生成树的端口状态和端口角色
  • 3、STP根交换机以及根端口的选举
  • 4、STP指定交换机以及指定端口的选举

1、STP生成树协议简介

通过链路冗余的方法解决了由于单链路或单交换机故障引起的网络中断,提高了网络的可用性。当在第二层采用冗余时,又会带来广播风暴、MAC地址不稳定、重复帧拷贝等问题,此时就需要启用STP(Spanning-Tree Protocol:生成树协议)来解决这个问题。

根据思科私有和IEEE标准的STP,分为以下几种STP。由于并不是每个企业都会使用思科的设备,所以为了理解通用原理,尽量参考使用IEEE取学习,本文讲解STP和RSTP。

分类协议
思科私有PVST
思科私有PVST+
思科私有Rapid-PVST
IEEE标准STP
IEEE标准RSTP
IEEE标准MSTP

2、STP生成树的端口状态和端口角色

理解STP的端口状态和角色很重要,它可以帮助理解STP协议从应用到完成的过程。
STP 五种端口状态和RSTP 三种端口状态对比:

STP端口状态RSTP端口状态
禁用(Disable )丢弃(Discarding)
阻塞(Blocking)丢弃(Discarding)
侦听(Listening)丢弃(Discarding)
学习(Learning)学习(Learning)
转发(Forwarding)转发(Forwarding)

由上表可见,RSTP把STP端口状态中的Disable、Blocking、Listening状态进行了整合,因为这三种状态都不进行包的转发。


STP 端口角色和RSTP端口角色的对比

STP端口角色RSTP端口角色
根端口(Root Port)根端口(Root Port)
指定端口(Designated Port)指定端口(Designated)
非指定端口备份端口(Backup Port)
禁用端口替代端口 (Alternative Port)

端口角色功能解释

端口角色位置解释
禁用端口存在于非根网桥和根网桥上生成树中不起作用的端口
根端口存在于非根网桥上非根交换机上距离根交换机最近的端口,根端口会将数据传送给根桥用于传输,是交换机端口去往跟桥的最佳路径。
替代端口存在于非根网桥上用来提供替代去往根网桥路径的端口,即替换当前根端口,工作在稳定拓扑中为丢弃状态。
备份端口存在于非根网桥上充当指定交换机的那个网段提供一条备份链路,工作在稳定拓扑中为丢弃状态。
指定端口存在于非根网桥和根网桥上对于根网桥来说,所有端口都为指定端口;对于非根网桥来说,指定端口根据需要与根交换机之间收发数据。
非指定端口存在于非根网桥上不转发数据,被阻塞了的端口。

【注意】备份端口主存在于两种情况
①两端口通过点到点链路连接成为环路
②网桥与共享LAN网段有两条或两条以上链路的连接,如下图:

网桥与共享LAN网段有两条链路


3、STP根交换机以及根端口的选举

在学会判断之前,我们应该先看下交换机关于生成树的信息,这样比较好理解判断的规则的依据是什么,执行命令Switch#show spanning-tree 或者Switch#show spanning-tree brief

SPANNING-TREE

【注释】

  • RID:Root ID,即根桥ID
  • BID:Bridge ID,即非根桥ID
  • PID:Port ID,即端口ID
  • cost值:与路径(带宽)花费相映射的一个值,见下表
速度花费
10Gb/s2
1Gb/s4
100Mb/s19
10Mb/s100

因为STP崇尚“小而美”的纲领,所以 priority值越小、mac值地址越小、cost值越小、端口id(f0/1< f0/2)越小,反而级别高一些。“谁更小”成为判断是否能成为根网桥或根端口,指定端口的标准。

  • 根网桥的选举
    ①priority值小的交换机优先;若相等,则判断②
    ②mac地址小的交换机优先

由此可见,根桥的选择只需用到上图中的RID,即priority值和mac地址。

  • 根端口的选举
    ①cost值小的端口优先;若相等,则判断②
    ②BID的priority值小的交换机优先;若相等,则判断③
    ③BID的mac值小的交换机优先;若相等,则判断④【参考图3-1】
    这里写图片描述
    ④发送者BID相同,比较发送者PID;若相等,则判断⑤【参考图3-2】
    这里写图片描述
    ⑤发送者PID相同,接受者的PID 【参考图3-3】
    这里写图片描述

4、STP指定交换机以及指定端口的选举

  • 指定端口的选举(若条件①相等,比条件②,依此类推)
    ①比较cost值
    ②比较BID值
    ③比较PID值

这篇关于理解STP(spanning-tree)生成树协议中各种端口的选举的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/522987

相关文章

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 1287 Networking(prim or kruscal最小生成树)

题意给你点与点间距离,求最小生成树。 注意点是,两点之间可能有不同的路,输入的时候选择最小的,和之前有道最短路WA的题目类似。 prim代码: #include<stdio.h>const int MaxN = 51;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int P;int prim(){bool vis[MaxN];

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D

hdu 1102 uva 10397(最小生成树prim)

hdu 1102: 题意: 给一个邻接矩阵,给一些村庄间已经修的路,问最小生成树。 解析: 把已经修的路的权值改为0,套个prim()。 注意prim 最外层循坏为n-1。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstri

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

poj 3723 kruscal,反边取最大生成树。

题意: 需要征募女兵N人,男兵M人。 每征募一个人需要花费10000美元,但是如果已经招募的人中有一些关系亲密的人,那么可以少花一些钱。 给出若干的男女之间的1~9999之间的亲密关系度,征募某个人的费用是10000 - (已经征募的人中和自己的亲密度的最大值)。 要求通过适当的招募顺序使得征募所有人的费用最小。 解析: 先设想无向图,在征募某个人a时,如果使用了a和b之间的关系

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝