owned this note
owned this note
Published
Linked with GitHub
---
title: Spanning Tree Protocol
tags: Cisco IOS, networking, manual, reference, router, switch, technical
---
<header>
<h6>Spanning Tree Protocol</h6>
> [toc]
</header>
---
# Overview
**Spanning Tree Protocol (STP)** is a **loop-prevention** network protocol that allows for redundancy while creating a loop-free Layer 2 topology.
Without STP enabled, Layer 2 loops can form, causing broadcast, multicast and unknown unicast frames to loop endlessly. This can bring down a network within a very short amount of time.
All switches that participate in STP exchange <b><abbr title="Bridge Port Data Unit">BPDU</abbr> frames</b> to determine which switch has the lowest **bridge ID (BID)** on the network. The switch with the lowest BID automatically becomes the **root bridge** for the spanning tree algorithm calculations. Each switch uses the spanning tree algorithm to determine which ports to block, in order to create the **shortest path** to the root bridge.
When the spanning tree algorithm has determined which paths are most desirable relative to each switch, it assigns port roles to the participating switch ports. The STP port roles are:
* **Alternate** – Alternate or backup ports are automatically placed in a **blocking** state to prevent loops. Alternate ports are selected only on trunk links where neither end is a root port.
* **Root** – Root ports are switch ports that are **closest to the root bridge**.
* **Designated** – Designated ports are all non-root ports that STP permits to **forward traffic** on the network. If one end of a trunk is a root port, then the other end will be a designated port. All ports on the root bridge are designated ports.
:::info
A port that is administratively shut down is referred to as a **disabled** port.
:::
# BPDU Frames
A BPDU is a messaging frame that is exchanged by switches for STP. Each BPDU contains a **Bridge ID (BID)** that identifies the switch that sent the BPDU. The BID contains a priority value, the MAC address of the sending switch, and an optional extended system ID. The lowest BID value is determined by the combination of these three fields.

# Root Bridge Election
**All switches in the broadcast domain participate in the election process:**
<ol class='step-list'>
<li>After a switch boots, it begins to send out BPDU frames every two seconds. These BPDU frames contain the switch BID and the root ID.</li>
<li>As the switch forwards its BPDU frames, other switches in the broadcast domain read the root ID information from the BPDU frames. If the root ID from a BPDU that has been received is lower than the root ID on the receiving switch, then the receiving switch updates its root ID, which identifies the adjacent switch as the root bridge.</li>
<li>The switch now forwards new BPDU frames with the lower root ID to the other switches. Eventually, the switch with the lowest BID ends up being identified as the root bridge for the spanning tree instance.</li>
</ol>
:::warning
There is a root bridge elected for each spanning tree instance. Therefore, it is possible to have multiple distinct root bridges within a LAN.
:::
# STP Path Cost
When the root bridge has been elected for the spanning tree instance, the spanning tree algorithm starts the process of determining the best paths to the root bridge from all destinations in the broadcast domain.
The path information is determined by **summing** up the **individual port costs** along the path from each starting point within the network, to the root bridge. Paths with the **lowest cost** become **preferred**, and all other redundant paths are blocked.
**The default port costs are defined by the speed at which the port operates:**
| Link Speed | Current Cost | Original Cost |
| ---------- | ------------ | ------------- |
| 10 Gb/s | 2 | 1 |
| 1 Gb/s | 4 | 1 |
| 100 Mb/s | 19 | 10 |
| 10 Mb/s | 100 | 100 |
:::info
As newer, faster Ethernet technologies become available, the path cost values may change to accommodate the new speeds. The non-linear numbers in the table accommodate some improvements to the older Ethernet standard.
:::
Although switch ports have a default port cost associated with them, the port cost is configurable. The ability to configure individual port costs gives the administrator the flexibility to manually control the spanning tree paths to the root bridge.
To configure the port cost of an interface, use the <code><b>spanning-tree cost</b> <i>value</i></code> interface configuration command. The value can be between 1 and 200'000'000.
To verify the port and path cost to the root bridge, enter the <code><b>show spanning-tree</b></code> command. The **Cost** field is the total path cost to the root bridge.
# Root Bridge Configuration
When an administrator wants a specific switch to become a root bridge, the bridge priority value must be adjusted to ensure it is lower than the bridge priority values of all the other switches on the network.
**There are two ways to configure the bridge priority value of a switch:**
To manually configure the bridge priority value, use the <code><b>spanning-tree vlan</b> <i>vlan-id</i> <b>priority</b> <i>value</i></code> global configuration mode command. This command gives more granular control over the bridge priority value. The priority value is configured in **increments of 4'096** between 0 and 61'440.
To automatically ensure that the switch has the lowest bridge priority value, use the <code><b>spanning-tree vlan</b> <i>vlan-id</i> <b>root primary</b></code> global configuration command. The priority for the switch will be set to the predefined value of **24'576** or to the highest multiple of 4,096 that is less than the lowest bridge priority detected on the network.
If an alternate root bridge is desired, use the <code><b>spanning-tree vlan</b> <i>vlan-id</i> <b>root secondary</b></code> global configuration mode command. This command sets the priority for the switch to the predefined value of **28'672**. This option assumes that the rest of the switches in the network have the default 32'768 priority value defined.
---
---
{%hackmd 7PGmjAHeTXak2VUM3iw5Wg %}