BGP Path selection relies on the BGP attributes. I have described the eight most important BGP attributes in my previous BGP Basic Information post.
Weight: The path with the highest weight is preferred. This is only locally significant and not affect any other router within the AS. Cisco only, used for outbound path selection
Local Preference: The path with the highest local preference is preferred. This is not locally significant and will affect other routers in the same AS. Used for outbound path selection
Originate: A path that originated on the local router is preferred to any paths learnt from a BGP peer. Cisco adds a weight of, 32768 to any prefixes advertised into the local router.
AS Path: The shortest AS path is preferred. Used for inbound path selection
Origin: Where was the path learnt from originally; IGP, INCOMPLETE. IGP via network statement and INCOMPLETE via a redistribution command. IGP is preferred to INCOMPLETE.
Multi-Exit Discriminator (MED): Lowest MED is preferred. Only performed if the first hop AS is identical. If the first hop is different, then this is skipped.
Paths: By default, only a single path is installed into the routing table. This can be changed using the maximum-paths
command in Cisco and Arista.
Router ID: Compare the router ID of the peer that the path is learnt from. Lower is preferred.BGP Synchronisation
I’ll go over a few of these attributes with labs
Topology
I have created a small 4 router topology that I will be using to change different attribute parameters.
Weight/Router ID
- The weight is a Cisco proprietary attribute
- Weight is not exchanged between routers
- Local to the router
- Highest weight is the preferred path
In this example, there are is a network 200.0.0.1/32
that R1 would like to connect to. There are two direct paths, one via ISP1 and another via ISP3.
Update message sent from ISP3 to R1 containing the directly connected networks known. Network 200.0.0.1/32
is in there.
Back on the R1 routing table, the routes are shown.
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
R1#sh ip route Gateway of last resort is not set 1.0.0.0/8 is variably subnetted, 2 subnets, 2 masks C 1.1.1.0/24 is directly connected, GigabitEthernet0/0 L 1.1.1.1/32 is directly connected, GigabitEthernet0/0 2.0.0.0/8 is variably subnetted, 2 subnets, 2 masks C 2.2.2.0/24 is directly connected, GigabitEthernet0/1 L 2.2.2.1/32 is directly connected, GigabitEthernet0/1 23.0.0.0/24 is subnetted, 1 subnets B 23.23.23.0 [20/0] via 2.2.2.2, 00:08:19 200.0.0.0/32 is subnetted, 1 subnets B 200.0.0.1 [20/0] via 2.2.2.2, 00:08:19 |
Adding the same redistribute connected
to ISP1 will also advertise 200.0.0.1/32
to R1. Once that has been advertised, to R1, R1 has updated its routing table to show the route to 200.0.0.1/32
is no via ISP1.
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
R1#sh ip route Gateway of last resort is not set 1.0.0.0/8 is variably subnetted, 2 subnets, 2 masks C 1.1.1.0/24 is directly connected, GigabitEthernet0/0 L 1.1.1.1/32 is directly connected, GigabitEthernet0/0 2.0.0.0/8 is variably subnetted, 2 subnets, 2 masks C 2.2.2.0/24 is directly connected, GigabitEthernet0/1 L 2.2.2.1/32 is directly connected, GigabitEthernet0/1 12.0.0.0/24 is subnetted, 1 subnets B 12.12.12.0 [20/0] via 1.1.1.2, 00:00:07 23.0.0.0/24 is subnetted, 1 subnets B 23.23.23.0 [20/0] via 2.2.2.2, 00:11:34 200.0.0.0/32 is subnetted, 1 subnets B 200.0.0.1 [20/0] via 1.1.1.2, 00:00:07 |
ISP1 has replaced ISP2 as the preferred path because of the neighbour id
is lower on ISP1 1.1.1.1
, compared to ISP2 2.2.2.2
.
I have modified the router ID on ISP1 to be 1.1.1.2
and ISP3 to be 1.1.1.1
. The peers have been reset and the routes have been relearnt. This time, however, the route is pointing via ISP3, 2.2.2.2
.
0 1 2 3 |
router bgp <AS-number> bgp router-id <router-id> |
0 1 2 3 4 5 6 |
R1#sh ip bgp summary Neighbor V AS MsgRcvd MsgSent TblVer InQ OutQ Up/Down State/PfxRcd 1.1.1.2 4 1 6 7 6 0 0 00:00:57 3 2.2.2.2 4 3 6 7 6 0 0 00:00:56 3 |
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
R1#sh ip route Gateway of last resort is not set 1.0.0.0/8 is variably subnetted, 2 subnets, 2 masks C 1.1.1.0/24 is directly connected, GigabitEthernet0/0 L 1.1.1.1/32 is directly connected, GigabitEthernet0/0 2.0.0.0/8 is variably subnetted, 2 subnets, 2 masks C 2.2.2.0/24 is directly connected, GigabitEthernet0/1 L 2.2.2.1/32 is directly connected, GigabitEthernet0/1 12.0.0.0/24 is subnetted, 1 subnets B 12.12.12.0 [20/0] via 1.1.1.2, 00:02:11 23.0.0.0/24 is subnetted, 1 subnets B 23.23.23.0 [20/0] via 2.2.2.2, 00:02:11 200.0.0.0/32 is subnetted, 1 subnets B 200.0.0.1 [20/0] via 2.2.2.2, 00:02:11 |
Now that ISP2 is the preferred route for the network 200.0.0.1
. I will change the weight to make ISP1 the preferred route and clear the BGP neighbours to start fresh again.
0 1 2 3 |
router bgp <AS-number> neighbor <neighbor-ip-address> weight <value> |
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
R1(config-router)#do sh ip route Gateway of last resort is not set 1.0.0.0/8 is variably subnetted, 2 subnets, 2 masks C 1.1.1.0/24 is directly connected, GigabitEthernet0/0 L 1.1.1.1/32 is directly connected, GigabitEthernet0/0 2.0.0.0/8 is variably subnetted, 2 subnets, 2 masks C 2.2.2.0/24 is directly connected, GigabitEthernet0/1 L 2.2.2.1/32 is directly connected, GigabitEthernet0/1 12.0.0.0/24 is subnetted, 1 subnets B 12.12.12.0 [20/0] via 1.1.1.2, 00:00:36 23.0.0.0/24 is subnetted, 1 subnets B 23.23.23.0 [20/0] via 2.2.2.2, 00:00:36 200.0.0.0/32 is subnetted, 1 subnets B 200.0.0.1 [20/0] via 1.1.1.2, 00:00:36 |
Local Preference
- Can be used to choose the outbound external BGP path
- It is sent to all iBGP peers in the same AS
- No exchanged between eBGP peers
- Default attribute is 100
- Highest is preferred
The topology has changed. There is no iBGP in AS 65001 and the connections to ISP1 and ISP3 have been moved to the new R2 and R3 routers in AS 65001.
The networks learnt via ISP1 and ISP3 have been advertised into iBGP. As there is not a full mesh or route reflector, only R1 will learn about all the networks.
I have added the command to R2 and R3 so that R1 will know how to reach the next hop ISP routers.R3(config-router)#neighbor 10.10.13.1 next-hop-self
R2(config-router)#neighbor 10.10.12.1 next-hop-self
The network 200.0.0.1
is learnt via both ISP1 and ISP3. Only the route via ISP1 is installed in the routing table.
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
R1(config-router)#do sh ip bgp BGP table version is 6, local router ID is 10.10.13.1 Status codes: s suppressed, d damped, h history, * valid, > best, i - internal, r RIB-failure, S Stale, m multipath, b backup-path, f RT-Filter, x best-external, a additional-path, c RIB-compressed, Origin codes: i - IGP, e - EGP, ? - incomplete RPKI validation codes: V valid, I invalid, N Not found Network Next Hop Metric LocPrf Weight Path *>i 1.1.1.0/24 10.10.12.2 0 100 0 1 ? *>i 2.2.2.0/24 10.10.13.2 0 100 0 3 ? *>i 12.12.12.0/24 10.10.12.2 0 100 0 1 ? *>i 23.23.23.0/24 10.10.13.2 0 100 0 3 ? *>i 200.0.0.1/32 10.10.12.2 0 100 0 1 ? * i 10.10.13.2 0 100 0 3 ? |
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
R1(config-router)#do sh ip route Gateway of last resort is not set 1.0.0.0/24 is subnetted, 1 subnets B 1.1.1.0 [200/0] via 10.10.12.2, 00:00:32 2.0.0.0/24 is subnetted, 1 subnets B 2.2.2.0 [200/0] via 10.10.13.2, 00:00:32 10.0.0.0/8 is variably subnetted, 4 subnets, 2 masks C 10.10.12.0/24 is directly connected, GigabitEthernet0/2 L 10.10.12.1/32 is directly connected, GigabitEthernet0/2 C 10.10.13.0/24 is directly connected, GigabitEthernet0/3 L 10.10.13.1/32 is directly connected, GigabitEthernet0/3 12.0.0.0/24 is subnetted, 1 subnets B 12.12.12.0 [200/0] via 10.10.12.2, 00:00:32 23.0.0.0/24 is subnetted, 1 subnets B 23.23.23.0 [200/0] via 10.10.13.2, 00:00:32 200.0.0.0/32 is subnetted, 1 subnets B 200.0.0.1 [200/0] via 10.10.12.2, 00:00:32 |
To modify this, local preference will be used to prefer ISP3 over ISP1. I have first set this on R1 with a prefix list and route map. This has been successful in changing the route to go via ISP3.
0 1 2 3 4 5 6 7 8 9 |
ip prefix-list PL_200NET seq 5 permit 200.0.0.1/32 route-map LOCAL-PREF-150 permit 10 match ip address prefix-list PL_200NET set local-preference 150 router bgp 65001 neighbor 10.10.13.2 route-map LOCAL-PREF-150 in |
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
R1(config-router)#do sh ip bgp BGP table version is 4, local router ID is 10.10.13.1 Status codes: s suppressed, d damped, h history, * valid, > best, i - internal, r RIB-failure, S Stale, m multipath, b backup-path, f RT-Filter, x best-external, a additional-path, c RIB-compressed, Origin codes: i - IGP, e - EGP, ? - incomplete RPKI validation codes: V valid, I invalid, N Not found Network Next Hop Metric LocPrf Weight Path *>i 1.1.1.0/24 10.10.12.2 0 100 0 1 ? *>i 12.12.12.0/24 10.10.12.2 0 100 0 1 ? *>i 200.0.0.1/32 10.10.13.2 0 150 0 3 ? * i 10.10.12.2 0 100 0 1 ? |
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
R1(config-router)#do sh ip route Gateway of last resort is not set 1.0.0.0/24 is subnetted, 1 subnets B 1.1.1.0 [200/0] via 10.10.12.2, 00:03:34 10.0.0.0/8 is variably subnetted, 4 subnets, 2 masks C 10.10.12.0/24 is directly connected, GigabitEthernet0/2 L 10.10.12.1/32 is directly connected, GigabitEthernet0/2 C 10.10.13.0/24 is directly connected, GigabitEthernet0/3 L 10.10.13.1/32 is directly connected, GigabitEthernet0/3 12.0.0.0/24 is subnetted, 1 subnets B 12.12.12.0 [200/0] via 10.10.12.2, 00:03:34 200.0.0.0/32 is subnetted, 1 subnets B 200.0.0.1 [200/0] via 10.10.13.2, 00:03:34 |
This next change, I would like to see the local preference propagated inside the AS. I have moved the route map to R3, applying the local preference of 150 as the route is learnt from ISP3.
0 1 2 3 4 5 6 7 8 9 |
ip prefix-list PL_200NET seq 5 permit 200.0.0.1/32 route-map LOCAL-PREF-150 permit 10 match ip address prefix-list PL_200NET set local-preference 150 router bgp 65001 neighbor 2.2.2.2 route-map LOCAL-PREF-150 in |
This has been successful, as shown on R1.
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
R1(config-router)#do sh ip bgp BGP table version is 9, local router ID is 10.10.13.1 Status codes: s suppressed, d damped, h history, * valid, > best, i - internal, r RIB-failure, S Stale, m multipath, b backup-path, f RT-Filter, x best-external, a additional-path, c RIB-compressed, Origin codes: i - IGP, e - EGP, ? - incomplete RPKI validation codes: V valid, I invalid, N Not found Network Next Hop Metric LocPrf Weight Path *>i 1.1.1.0/24 10.10.12.2 0 100 0 1 ? *>i 12.12.12.0/24 10.10.12.2 0 100 0 1 ? *>i 200.0.0.1/32 10.10.13.2 0 150 0 3 ? * i 10.10.12.2 0 100 0 1 ? |
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
R1(config-router)#do sh ip route Gateway of last resort is not set 1.0.0.0/24 is subnetted, 1 subnets B 1.1.1.0 [200/0] via 10.10.12.2, 00:04:08 10.0.0.0/8 is variably subnetted, 4 subnets, 2 masks C 10.10.12.0/24 is directly connected, GigabitEthernet0/2 L 10.10.12.1/32 is directly connected, GigabitEthernet0/2 C 10.10.13.0/24 is directly connected, GigabitEthernet0/3 L 10.10.13.1/32 is directly connected, GigabitEthernet0/3 12.0.0.0/24 is subnetted, 1 subnets B 12.12.12.0 [200/0] via 10.10.12.2, 00:04:08 200.0.0.0/32 is subnetted, 1 subnets B 200.0.0.1 [200/0] via 10.10.13.2, 00:02:37 |
AS Path
The last attribute I will go over is the AS path. This is for advertising networks to external BGP peers. In this topology, I will advertise a network of 100.123.10.0/24
that is owned by AS 65001. This network will be advertised to both ISP1 and ISP3.
ISP2 will learn about the network 100.123.10.0/24
from both ISP1 and ISP2 and decide which is the preferred path.
ISP2 has learnt about all the routes now, specifically 100.12.10.0/24
. The best path for this route is via ISP1, which is expected due to the best path being chosen based on router ID.
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
ISP2(config-router)#do sh ip bgp BGP table version is 17, local router ID is 23.23.23.2 Status codes: s suppressed, d damped, h history, * valid, > best, i - internal, r RIB-failure, S Stale, m multipath, b backup-path, f RT-Filter, x best-external, a additional-path, c RIB-compressed, Origin codes: i - IGP, e - EGP, ? - incomplete RPKI validation codes: V valid, I invalid, N Not found Network Next Hop Metric LocPrf Weight Path *> 1.1.1.0/24 12.12.12.1 0 0 1 ? *> 2.2.2.0/24 23.23.23.1 0 0 3 ? * 10.10.12.0/24 23.23.23.1 0 3 65001 ? *> 12.12.12.1 0 1 65001 ? * 10.10.13.0/24 23.23.23.1 0 3 65001 ? *> 12.12.12.1 0 1 65001 ? r> 12.12.12.0/24 12.12.12.1 0 0 1 ? r> 23.23.23.0/24 23.23.23.1 0 0 3 ? * 100.123.10.0/24 23.23.23.1 0 3 65001 ? *> 12.12.12.1 0 1 65001 ? * 200.0.0.1/32 23.23.23.1 0 0 3 ? *> 12.12.12.1 0 0 1 ? |
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
ISP2(config-router)#do sh ip route Gateway of last resort is not set 1.0.0.0/24 is subnetted, 1 subnets B 1.1.1.0 [20/0] via 12.12.12.1, 00:06:12 2.0.0.0/24 is subnetted, 1 subnets B 2.2.2.0 [20/0] via 23.23.23.1, 00:04:24 10.0.0.0/24 is subnetted, 2 subnets B 10.10.12.0 [20/0] via 12.12.12.1, 00:05:25 B 10.10.13.0 [20/0] via 12.12.12.1, 00:05:25 12.0.0.0/8 is variably subnetted, 2 subnets, 2 masks C 12.12.12.0/24 is directly connected, GigabitEthernet0/1 L 12.12.12.2/32 is directly connected, GigabitEthernet0/1 23.0.0.0/8 is variably subnetted, 2 subnets, 2 masks C 23.23.23.0/24 is directly connected, GigabitEthernet0/2 L 23.23.23.2/32 is directly connected, GigabitEthernet0/2 100.0.0.0/24 is subnetted, 1 subnets B 100.123.10.0 [20/0] via 12.12.12.1, 00:05:25 200.0.0.0/32 is subnetted, 1 subnets B 200.0.0.1 [20/0] via 12.12.12.1, 00:05:25 |
On router R2 I will prepend AS 65001 that will make it look as though there are more AS’ to pass through that via R3.
0 1 2 3 4 5 6 7 |
#R2 Config route-map RM_AS_PREPEND permit 10 set as-path prepend 65001 65001 router bgp 65001 neighbor 1.1.1.2 route-map RM_AS_PREPEND out |
After the change, the routes learnt via BGP can see that all routes from R2 have the AS 65001 prepended. This could have been narrowed down to only the network 100.123.1.0/24
with the use of a prefix list. However, as this is just a lab, I have left it. But it does highlight the importance of being as specific as possible with BGP.
The route now chose is via ISP3.
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
ISP2(config-router)#do sh ip bgp BGP table version is 20, local router ID is 23.23.23.2 Status codes: s suppressed, d damped, h history, * valid, > best, i - internal, r RIB-failure, S Stale, m multipath, b backup-path, f RT-Filter, x best-external, a additional-path, c RIB-compressed, Origin codes: i - IGP, e - EGP, ? - incomplete RPKI validation codes: V valid, I invalid, N Not found Network Next Hop Metric LocPrf Weight Path *> 1.1.1.0/24 12.12.12.1 0 0 1 ? *> 2.2.2.0/24 23.23.23.1 0 0 3 ? *> 10.10.12.0/24 23.23.23.1 0 3 65001 ? * 12.12.12.1 0 1 65001 65001 65001 ? *> 10.10.13.0/24 23.23.23.1 0 3 65001 ? * 12.12.12.1 0 1 65001 65001 65001 ? r> 12.12.12.0/24 12.12.12.1 0 0 1 ? r> 23.23.23.0/24 23.23.23.1 0 0 3 ? *> 100.123.10.0/24 23.23.23.1 0 3 65001 ? * 12.12.12.1 0 1 65001 65001 65001 ? * 200.0.0.1/32 23.23.23.1 0 0 3 ? *> 12.12.12.1 0 0 1 ? |
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
ISP2(config-router)#do sh ip route Gateway of last resort is not set 1.0.0.0/24 is subnetted, 1 subnets B 1.1.1.0 [20/0] via 12.12.12.1, 00:13:06 2.0.0.0/24 is subnetted, 1 subnets B 2.2.2.0 [20/0] via 23.23.23.1, 00:11:18 10.0.0.0/24 is subnetted, 2 subnets B 10.10.12.0 [20/0] via 23.23.23.1, 00:02:27 B 10.10.13.0 [20/0] via 23.23.23.1, 00:02:27 12.0.0.0/8 is variably subnetted, 2 subnets, 2 masks C 12.12.12.0/24 is directly connected, GigabitEthernet0/1 L 12.12.12.2/32 is directly connected, GigabitEthernet0/1 23.0.0.0/8 is variably subnetted, 2 subnets, 2 masks C 23.23.23.0/24 is directly connected, GigabitEthernet0/2 L 23.23.23.2/32 is directly connected, GigabitEthernet0/2 100.0.0.0/24 is subnetted, 1 subnets B 100.123.10.0 [20/0] via 23.23.23.1, 00:02:27 200.0.0.0/32 is subnetted, 1 subnets B 200.0.0.1 [20/0] via 12.12.12.1, 00:12:19 |