zoukankan      html  css  js  c++  java
  • STP详解

    STP详解

    Write From YangWj

    Wednesday, March 5, 2014

    一、 生成树协议

    STP的主要任务是阻止在第2层网络(网桥或交换机)产生网络环路,它警惕的监视着网络中所有的链路,通过关闭任何冗余的接口来确保在网络中不会产生环路。STP采用生成树算法,它首先创建一个拓扑数据库,然后搜集并破坏掉冗余的链路

    二、 生成树术语

    根桥:根桥是桥ID最低的网桥

    非根桥:除根桥外其他的网桥都是非根桥。

    BPDU(桥协议数据单元):交换机之间用来交互的信息,使用BPDU里面的参数进行对比,然后再传给某个邻居,并且放入他们从另外邻居收到的BPDU。

    桥ID:桥ID是由优先级和MAC地址组合来决定的,STP利用桥ID来跟踪网络中所有的交换机。

    根端口:直接连到根桥的链路所在端口,或者到根桥路径最短的端口。

    指定端口:有最低开销的端口就是指定端口,指定端口被标记为转发端口。在根交换机上的每个端口都是指定端口。

    非指定端口:开销比指定端口高的端口,它被置为阻塞状态。

    转发端口:能够转发帧的端口。

    阻塞端口:不能转发帧,但始终监听帧。

    端口开销:两台交换机之间有多条链路且都不是根端口时,就根据端口开销来决定最佳路径,链路的开销取决于链路的带宽。

    三、 根桥选举

    桥ID用来选举根桥,,并决定根端口。桥ID为8个字节长,包括设备的优先级和MAC地址,默认所有的优先级都是32768 。若更改则要求为4096的倍数。

    网络中的交换机默认都是每2秒发送一次BPDU,被发送到网桥/交换机的所有活动的端口上。桥ID最小的网桥就被选举为根桥。一般我们会手动将要作为根桥的交换机的优先级降低,这样会比较有效率。

    四、 生成树端口状态

    阻塞:无法转发帧,但是会监听。

    侦听:侦听BPDU,确保在传送数据帧之前,网络上没有环路产生。处于此状态在没有形成mac地址表时,就准备转发数据帧。

    学习:交换机端口侦听BPDU时并学习交换式网络中的所有路径。此时形成了mac地址表,但不能转发数据帧。转发延迟意味着将端口从侦听状态转换到学习状态所花费的时间,默认15秒。

    转发:发送并能接收所有的数据帧,如果在学习状态结束时,端口仍然是制定端口或根端口,它就进入转发状态。

    五、 实验部分

    (一) 根桥的选举

    实验拓扑图

    clip_image001

    连接好了之后我们可以清楚的看到S3的F0/12被阻塞了

    1. 查看S1

    clip_image003

    2. 查看S2(它是根桥)

    clip_image005

    3. 查看S3

    clip_image007

    4. 查看S4

    clip_image009

    5. 修改S1的优先级,使其成为根桥

    clip_image011

    6. 此时的网络选举结果如下

    clip_image012

    7. 查看S1的信息(它已作为根桥)

    clip_image014

    8. 实验结论如下

    a) 选举根桥时用优先级和mac地址作为依据。

    b) 优先使用优先级作为选举依据。

    c) 优先级小的被选举为根桥。

    d) 优先级相同时mac值小的被选举成根桥。

    (二) 探索1——优先级与阻塞端口

    实验拓扑图

    clip_image016

    首先右图是左图的复制,照理说他们的阻塞端口(S4上)应该都是一样的,那么为什么在复制过去之后就成了这样的呢?

    1. 查看有图中的CopyS1信息(它还是根桥,这个肯定的)

    clip_image018

    2. 查看右图CopyS2的信息

    clip_image020

    3. 查看右图CopyS3中的信息

    clip_image021

    4. 查看右图CopyS4中的信息

    clip_image023

    5. 通过将CopyS2和CopyS3的信息分析对比得到

    clip_image025

    6. 再次分析左图中S2和S3的信息

    clip_image027

    7. 修改左图S3的优先级(但要小于S1,因为它是根桥)

    clip_image029

    8. 同理修改右图CopyS2的优先级

    clip_image031

    9. 查看左图S3和右图CopyS2的信息

    clip_image033

    10. 实验结论

    a) 端口阻塞的选择与上层交换机的优先级有关联

    b) 优先比较的是上层优先级,优先级大的被阻塞

    c) 上层优先级等同时比较mac地址,mac大的被阻塞

    (三) 探索2——端口号与阻塞端口

    实验拓扑图

    clip_image034

    上图中S1与S2连接,分别对应的端口为F0/1,F0/11,图中已经将根桥选举出来,并且阻塞了S2的F0/11端口。那么它又是如何进行选择的呢?

    1. 为了使实验得以稳定,将S1手动指定为根桥,即修改它的优先级

    clip_image036

    2. 查看S2的信息

    clip_image038

    3. 借助探索1的结论,上层的优先级完全一样,我们先复制一份

    clip_image039

    4. 对比CopyS2和CopyS1(或者S1和S2),发现只有Prio.Nbr的值异样

    clip_image041

    5. 更换右图中S2的F0/1为F0/15,得下(无变化)

    clip_image042

    6. 更换左图中S1的F0/1为F0/15,如下(阻塞端口被改变了)

    clip_image043

    7. 实验结论可得

    a) 端口阻塞的选择与根桥的接口有关系。

    b) 在优先级等同的时候才会用上层交换机端口号做选择。(不一定是根桥)

    c) 根桥接口号大的对应链路到下层交换机的端口会被阻塞。

  • 相关阅读:
    C++实现base64编码
    php实现base64编码
    美团2016研发工程师笔试题(绑鞋带问题)
    URL encode 与 URL decode 的C语言实现
    常用排序算法集合-C实现
    用文件实现计算器要求多进程同时写
    vim操作命令-笔记
    Can't connect to local MySQL server through socket
    小程序页面跳转数据丢失
    Vue路由 --登录状态的判断
  • 原文地址:https://www.cnblogs.com/ywj2013/p/3583229.html
Copyright © 2011-2022 走看看