在路由器之间动态的学习路由条目,形成路由表
IGP:以最快的速度,计算一个去往目标网络的最短的、无环的转发路径
-DV
RIP
IGRP
EIGRP
-LS
ISIS
OSPF
EGP:在不同的企业之间,实现大量路由的稳定可靠的传输,并且可以实现路由
的灵活控制,并且保证无环;
-BGP:border gateway protocol ,边界网关协议
用于连接不同的企业或者组织结构;
prefix/mask type priority cost next-hop , interface
数据库中 ---(priority/cost)---> 路由表中
-match packet :
最长匹配原则
money money home
优先级:表示的路由的稳定性,值越小越好;0-255 ;
Metric(度量值):表示的是去往一个目标网络的距离的远近,越小越好;
OSPF:
1、邻居表
2、数据库
3、路由表
-hello:是非可靠传输方式;
-DBD:隐式确认,通过DBD报文中的序列号字段进行确认;
-LSU:显式确认,每发送一个LSU,都会返回一个LSAck;
-LSR:显式确认,每发送一个LSR,都会返回一个LSAck;
-LSAck:仅仅对其他报文实现确认作用,但是本身的传输是不可靠的;
L2+L3+OSPF
BGP:
L2+L3+TCP+BGP - tcp 179
L2+L3+UDP+RIP - udp 520
L2+L3+OSFP - protocol-id : 89 , TCP/IP 路由技术卷1,2 | OSPF设计与实现 | OSPF命令手册
L2+L3+EIGRP - protocol-id:88
L2+ISIS
关于交换:
BCMSN chm/pdf
BGP工作原理:
1、邻居表:display bgp peer
2、数据库:display bgp routing-table
3、路由表
bgp {as} # as 分为公有和私有,[64512--65535]
peer {ip-address} as-number {对方设备的}
BGP邻居建立:
-内部邻居
R1;
bgp 64512 # 设备本地运行的 BGP AS 号;
router-id 1.1.1.1
peer 192.168.12.2 as-number 64512 #邻居路由器属于的 AS 号;
R2;
bgp 64512
router-id 2.2.2.2
peer 192.168.12.1 as-number 64512
display bgp peer # 查看设备上的 BGP 邻居表;
local-as
local-router-id
number of peers
peer v as msgrcvd msgsent outq up/down state prefrvcd
R1:
bgp 64512
peer 10.10.2.2 as-number 64512
# R1 主动向 10.10.2.2 发起一个 TCP 179 的链接;
# 10.10.2.2 必须位于 AS 64512
or
10.10.2.2 的回复报文,必须是属于as 64512 的;
# 对方回包时,所使用的源IP地址必须是 10.10.2.2 ,
否则不接受(这就是“更新源检测机制”)
为了解决“非直连端口建立邻居时”所面临的“更新源检测机制”,
所以我们在发送 BGP 链接请求时候,更改报文的源IP地址:
例如:
bgp 64512
peer 10.10.2.2 connect-interface loopback 0
强烈建议:
非直连端口建立BGP邻居关系时,两边的Peer命令,都使用
该参数;
非直连IBGP邻居关系建立:
1、配置IP
2、配置IGP
3、配置BGP
外部BGP邻居建立时候需要考虑的机制:
1、更新源检测机制 -- 与IBGP邻居是相同的;
2、直连检测机制
#在什么时候才会检查该机制
在建立EBGP时,并且发送的BGP报文的 TTL 为 1 时,才会检查;
#该机制的定义是什么
&去往邻居地址时,使用的必须是“直连路由”,
如果不是,则表示不满足“直连检测机制”,从而无法建立EBGP邻居
面对为了链路稳定为建立的“非直连的 EBGP 邻居关系”,我们需要修改 EBGP
报文的 TTL 值不是“1”即可。因为,一旦不是1,就不会关心该机制了。
bgp 64513
peere 10.10.2.2 ebgp-max-hop [255]
============================================================
IBGP邻居防环机制:
-IBGP水平分割
指的是从内部邻居路由器收到的路由,不会再次发送给其他的内部邻居;
解决方案:
-IBGP全互连
-BGP联盟
大AS:在外部邻居关系之间发送的报文中,使用的是大AS;
小AS: 在联盟内部的“内部邻居”之间肯定是用;
在联盟内部的“联盟成员AS”之间的特殊的外部邻居之间也使用;
R1:
bgp 64512
confederation id 200 # BGP联盟的号码,表示的是 大AS
peer 10.10.2.2 as-number 64512
peer 10.10.2.2 connect-interface loopback 10
R2:
bgp 64512
confederation id 200
confederation peer-as 64513
peer 10.10.1.1 as-number 64512 #与R1为内部邻居,所以使用小AS
peer 10.10.1.1 connect-interface loopback 0
peer 10.10.3.3 as-number 64513 #联盟内部的特殊的外部邻居,使用小AS
peer 10.10.3.3 connect-interface loopback 0
peer 10.10.3.3 ebgp-max-hop
peer 192.168.24.4 as-number 400 # 此时与R4建立邻居使用的是大AS
R3:
bgp 64513
confederation id 200
confederation peer-as 64512
peer 10.10.2.2 as-number 64512
peer 10.10.2.2 connect-interface loopback 10
peer 10.10.2.2 ebgp-max-hop
BGP (二)
IGP
EGP
BGP
IBGP
-IBGP的水平分割
#IBGP全互联
#联盟(大AS和小AS)
#路由反射器(route-reflector)
-当我们将一个路由器配置为BGP的“路由反射器”之后,
该路由器就会不关心“IBGP水平分割”机制。
-路由反射器 + 路由反射器客户端 = 路由反射 簇 (cluster)
R5;
bgp 64512
peer 10.10.4.4 reflect-client #将R4作为自己的客户端;
从而自己成为了反射器;
EBGP
BGP路由在传递过程下一跳的变化:
1、在内部邻居之间传递的时候,下一跳是不变化的;
2、在外部邻居之间传递的时候,下一跳是会变化的;
在AS的边界路由器上,对自己的内部邻居配置“下一跳自我”:
R7:
bgp 64513
peer 10.10.6.6 next-hop-local
# R7发送给 R6 的所有的路由的下一跳为 10.10.7.7 ;
BGP在什么情况下使用:
1、运营商之间使用 BGP ;
2、当企业具有多出口网络设计的时候,可以使用 BGP ;
3、当想对路由选路进行灵活控制的时候,可以使用BGP;
BGP 13 条选路原则:
1、权重(prefered value | weight ) ,私有属性,值越大越好;
2、local preference ,本地优先级,越大越好;
3、是否为本地起源
所谓本地起源,表示的是本地产生的BGP路由。
对于BGP路由器而言,BGP路由分为两种:
自己本地产生的
从其他路由器学习的
本地产生的,要优于 “从其他路由器”学习的路由
4、as-path长度 ,越短越好(属性as-path可以实现不同AS之间的路由转发环路的防护)
as-path 表示的是 BGP 路由在传递过程中,前后依次经历过的 AS 号的组成;
当BGP路由器发现收到的BGP路由的 AS-path 属性中包含了自己的 AS号,
则表明该路由在传递过程中,曾经穿越过自己的 AS ,
那么,就不接收该路由条目,以防止路由环路的发生;
as-path 的形成过程是:从右向左;
默认情况下,as-path在 外部邻居之间发送路由的时候,才会变化;
5、origin code ,本地起源属性( i > e > ? )
6、MED,值越小越好(只有当邻居AS相同时,才会进行比较)
7、EBGP优先于IBGP
8、去往BGP路由的下一跳的 IGP Metric ,越小越好;
9、负载均衡
如果开启的话,则将多个路由条目都放入到路由表中;
并且将 best 路由,发送给邻居;
10、越老越好(仅仅对于EBGP)
11、RID(router-id),越小越好;
12、Cluster list 长度,越短越好;
13、peer address ,越小越好;
====================================================================
R1:更改 BGP 属性 - local preference
1、匹配感兴趣的路由;
acl 2000
rule 5 permit source 80.80.80.0 0.0.0.255
2、创建路由策略
route-policy CCNA permit node 10
if-match acl 2000
apply local-preference 333
3、调用路由策略
bgp 100
peer 10.10.3.3 route-policy CCNA import # 调用入向路由策略
4、验证
display bgp routing-table #去往80 的路由,下一跳变成 R3;
display bgp routing-table peer 10.10.3.3 received-route
存在的问题:R1从R3收路由时,少了40和70的相关路由。
注意:
基本ACL在匹配路由条目时,只能匹配路由的前缀,不能匹配掩码;
扩展ACL是可以的;
=================================================================
R2:更改 BGP 属性 - as-path 属性
1、创建ACL,匹配感兴趣的路由(40.40.40.0/24)
acl 2004
rule 5 permit source 40.40.40.0 0.0.0.0
2、创建 route-plicy , 修改 as-path:添加一个 210,将as-path长度变为2;
route-policy R2-R4-IN permit node 10
if-match acl 2004
apply as-path 210 additive
route-policy R2-R4-IN permit node 100
3、调用路由策略
bgp 100
peer 192.168.24.4 route-policy R2-R4-IN import
4、验证、测试、保存
R2:
display bgp routing-table as-path
*> 40.40.40.0/24 10.10.3.3 200
10.10.2.2 100 200
==================================================================
acl 2000
rule 5 permit source 80.80.80.0 0.0.0.0 # 此时ACL匹配的是 prefix
rule max deny source any
40.40.40.0
70.70.70.0
Route-policy : CCNA 【route-map】
permit : 10 (matched counts: 7)
Match clauses :
if-match acl 2000
Apply clauses :
apply local-preference 333
[注意:]
route-plicy 最后有一个隐含的 deny any ;
如果想表示 permit any ;
route-policy {name} permit {node-id}
if-match #不写任何的匹配条件,则表示匹配所有;
apply {路由属性} # 在不写 if-math 的情况下,可以写 apply ;
R1:
bgp 100
peer 10.10.3.3 route-policy CCNA import
display bgp routing-table
少了 40 , 70 ;