STP生成树协议详解
看了网上关于STP生成树的解释感觉不是很懂,随即自己研究了一番
如有错误,欢迎指正,欢迎留言
--------------------------------------------------------------------------------------------------------------------
首先我们来了解一下为什么会有STP协议,即它能解决什么问题。
在企业里,为了防止线路故障,通常会做线路冗余,由于交换机会转发所有广播,所以会产生以下的问题:
1.广播风暴。广播会在交换网络里无限传播,且越来越严重,直至占满交换机资源。
2.重复帧。目标主机会收到越来越多的重复帧,这些重复帧可能每一个都需要回复。
3.MAC地址表不稳定。由于交换机的自学习,使得发送广播的主机的MAC地址(即源MAC)不停的出现在交换机不同的接口。
所以出现了STP生成树协议,将多余的线路自动阻塞,防止以上的问题;当有线路故障时,又会生成新的生成树,原本阻塞的某一段又会重新开始转发帧,以达到线路冗余的目的。
我们来熟悉一下STP生成树的术语:
桥ID:网桥的优先级(2字节)+本网桥最小MAC地址(6字节)
网桥优先级默认为32768
每一个交换机都有一个桥ID
端口ID:端口优先级(1字节)+端口号(1字节)
端口优先级默认为128
每一个端口都有一个端口ID
BPDU:桥协议数据单元,包含了网桥ID和Cost等信息
选举过程:
1.选择根桥
具有最小网桥ID的交换机成为根桥
2.每个网桥选择一个根端口
①选取端口(注意是端口)到达根桥Cost值最小的端口作为根端口
②若以上相同,则选取BPDU发送方网桥ID最小的
③若以上均相同,则选取BPDU发送方端口ID最小的
带宽 Cost
10Gbps 2
1Gbps 4
100Mbps 19
10Mbps 100
3.每一个段选择一个指定端口
①选取网桥(注意是网桥)到达根桥Cost值最小的端口作为根端口
②若以上相同,则选取BPDU发送方网桥ID最小的
③若以上均相同,则选取BPDU发送方端口ID最小的
注意:已经成为根端口的端口不再参与指定端口的选举
4.既不是根端口也不是指定端口的,进入阻塞状态
选举过程中端口的状态:
Disable:不发送任何报文(端口处于关闭状态)
Blocking:接收但不转发BPDU,不学习MAC地址,不接收也不转发帧(阻塞状态,但接收BPDU,需要时转为Listening)
Listening:接收且转发BPDU,不学习MAC地址,不接收也不转发帧(监听状态,发送和接收BPDU)
Learning:接收且转发BPDU,学习MAC地址,不接收也不转发帧(开始学习MAC地址)
Forwarding:接收且转发BPDU,学习MAC地址,接收并转发帧(开始转发数据包)
端口状态变化过程:
Blocking-->Listening-->Learning-->Forwarding
①网桥开始活动后自动由Blocking转为Listening。
②在Listening阶段完成选举(20s),若为根端口或者指定端口则转为Learning,否则Blocking。
③在Learning阶段(15s)开始学习MAC地址,为数据转发做准备工作。
④Forwarding阶段(15s)就可以开始数据转发了。
读者可以根据下面的拓扑图练习一下STP生成树
通过sh int | include bia 可以查看交换机的MAC地址
通过sh spanning-tree可以查看各端口的状态
谢谢阅读。
STP生成树协议详解的更多相关文章
- HTTP协议详解(转)
转自:http://blog.csdn.net/gueter/archive/2007/03/08/1524447.aspx Author :Jeffrey 引言 HTTP是一个属于应用层的面向对象的 ...
- HTTP协议详解
Author :Jeffrey 引言 HTTP 是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统.它于1990年提出,经过几年的使用与发展,得到不断地完善和 扩展. ...
- 动态选路、RIP协议&&OSPF协议详解
动态选路.RIP协议&&OSPF协议详解 概念 当相邻路由器之间进行通信,以告知对方每个路由器当前所连接的网络,这时就出现了动态选路.路由器之间必须采用选路协议进行通信,这样的选路协议 ...
- ASP.NET知识总结(3.HTTP协议详解)
引言 HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统.它于1990年提出,经过几年的使用与发展,得到不断地完善和扩展.目前在WWW中使用的是HTTP/1. ...
- 接口测试之HTTP协议详解
引言 HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统.它于1990年提出,经过几年的使用与发展,得到不断地完善和扩展.目前在WWW中使用的是HTTP/1. ...
- 计算机网络(12)-----HTTP协议详解
HTTP协议详解 http请求 http请求由三部分组成,分别是:请求行.消息报头.请求正文 (1)请求行 请求行以一个方法符号开头,以空格分开,后面跟着请求的URI和协议的版本,格式如下:Metho ...
- OSPF协议详解
CCNP OSPF协议详解 2010-02-24 20:30:22 标签:CCNP 职场 OSPF 休闲 OSPF(Open Shortest Path Fitst,ospf)开放最短路径优先协议,是 ...
- HTTP协议详解(真的很经典)
HTTP 是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统.它于1990年提出,经过几年的使用与发展,得到不断地完善和 扩展.目前在WWW中使用的是HTTP/1.0 ...
- HTTP协议详解--转载http://blog.csdn.net/gueter/article/details/1524447
引言 HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统.它于1990年提出,经过几年的使用与发展,得到不断地完善和扩展.目前在WWW中使用的是HTTP/1. ...
- 关于http协议详解
Author :Jeffrey 引言 HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统.它于1990年提出,经过几年的使用与发展,得到不断地完善和扩展.目前 ...
随机推荐
- clickhouse数据操常见执行语句
1.清空本地表数据 truncate table 数据库名.表名 :) select * from test_local; SELECT * FROM test_local Query id: ab1 ...
- 混合开发中,app内嵌h5页面时,安卓ios遇到的一些兼容问题及解决方法
1.input[type=checkbox]在ios端样式显示异常,黑色背景或边框,安卓正常 解决: input[type=checkbox]:checked{ background-color: t ...
- list转json tree的工具类
package com.glodon.safety.contingency.job; import com.alibaba.fastjson.JSON; import com.alibaba.fast ...
- PHP实现没有数据库提交form表单到后台并且显示出数据列表(Vuejs和Element-UI前端设计表单)
1.情境:如果你新建了个网站,却没有数据库服务器,如何把你的表单信息,提交到服务端后台,收集数据. 2.思路:如果用传统的form action 提交到一个form.php页面,此时只能存储一次数据, ...
- postgresql 创建索引
--查询索引 select * from pg_indexes where tablename='tab1'; --创建索引(查询用到哪几列,就对哪几个字段创建索引) CREATE INDEX ind ...
- leaflet 使用kriging.js实现前端自定义插值
1.GitHub地址:https://github.com/oeo4b/kriging.js 2.核心代码 var variogram = kriging.train(t, x, y, model, ...
- 推荐一个好用的.net开发框架
企业应用开发平台(Enterprise Develop Platform),以下简称EDP.EDP是一套集完整组织架构,全面权限体系,以及各类基础功能于一体的基于.net的企业应用开发平台.其最大的特 ...
- angular 16 路由守卫更新
在 angular16 中守卫使用方式进行了更新,route 守卫被弃用(取消了CanActivate的使用),新增了功能性守卫(CanActivateFn),支持 inject 注入,官网提供了一个 ...
- Vue Vue-Router params 传参 为空 path定义参数 参数 param is not repeatable
我在Vue-Router4.0.3版本上出现这个问题 因为官方 在2022年8月22日时废除了未定义的传参方式,所以必须使用定义的params. 解决办法: 在配置路由时:path路径上带上传值的ke ...
- mit 6.824 lab1 思路贴
前言 为遵守 mit 的约定,这个帖子不贴太多具体的代码,主要聊聊自己在码代码时的一些想法和遇到的问题. 这个实验需要我们去实现一个 map-reduce 的功能.实质上,这个实验分为两个大的板块,m ...