网络技术
H3C网络技术
H3C 设备CLI(命令行)管理
H3C基础配置知识
H3C 设备型号概述
H3C网络端口基础信息与配置
H3C网络设备概述
HCL模拟器使用简介
H3C WX2540H 本地portal认证+本地用户认证实现web认证
网络的基本概念与定义
VLAN简介与配置
生成树配置
STP简介与配置
RSTP简介
MSTP基本概念
交换机FTP和TFTP操作
配置文件与升级
网络设备登录管理方式
网络设备文件系统操作
H3C MSR路由器出口双线负载均衡
策略路由配置
以太网链路聚合
DHCP中继
防火墙简单配置实验
华为_HCIP
认识设备-硬件架构与逻辑平面
路由基础-HCIP
OSPF路由基础概述
Router LSA详解
OSPF-Network LSA(二类LSA)与区域内路由计算
OSPF-区域间路由计算
计算机网络-OSPF防环机制
计算机网络-RIP动态路由协议简介
OSPF区域外部路由计算
OSPF特殊区域-Stub区域
计算机网络-NSSA区域与Totally NSSA区域
OSPF路由汇总
OSPF其它特性
IS-IS路由协议基础概念
IS-IS基础概念二
IS-IS邻接关系建立
IS-IS链路状态数据库同步
IS-IS路由计算
IPv6基础概念
IPv6缩写规范与地址分类
ICMPv6基础知识
ICMPv6之NDP协议
计算机网络-IPv6地址配置
DHCPv6基础概念
DHCPv6配置
IPv6路由配置
路由策略与路由工具
计算机网络-Filter-Policy过滤策略
Route-Policy路由策略
策略路由概念与应用
MQC策略简介与配置
流量过滤策略
BGP的背景与概述
BGP基本概念
BGP报文类型简介
BGP状态机制与对等体表项
BGP路由生成与路由表
BGP路由通告原则
BGP基础实验配置
BGP路由优选概述
BGP路由优选原则一Preferred-Value
BGP路由优选原则二-本地优先级
BGP路由优选原则三-路由类型
BGP路由优选原则四-AS_Path属性
BGP路由优选原则五-Origin属性优选
BGP路由优选原则六-优选MED属性值最小的路由
BGP路由优选原则七-EBGP优于IBGP
BGP路由优选原则八-优选IGP Cost值小的路由
BGP路由负载分担
BGP路由反射器与Cluster list选路原则
BGP路由优选原则九-优选Router ID小的设备通告的路由
计算机网络-IP组播基础
组播地址与组播网络组成
组播数据转发原理与RPF
组播分发树与组播协议
IGMP协议简介
IGMPv1工作原理
IGMPv2工作原理简介
IGMPv3的工作原理
IGMP Snooping特性
计算机网络-PIM协议基础概念
PIM-DM密集模式工作原理
基于PIM-DM+IGMP的组播实验配置
PIM-SM(ASM)基础
PIM-SM(SSM)基本原理
PIM-SM组播实验
BFD检测机制
BFD配置实验
VRRP基础概念
VRRP工作原理与选举过程
VRRP主备切换与主备回切
VRRP基础实验一
RSTP基础概念
RSTP工作原理与P/A机制
MSTP概述
MSTP基础概念
MSTP工作原理概述
MSTP基础实验一(单域多实例)
计算机网络-VPN虚拟专用网络概述
计算机网络-GRE(通用路由封装协议)简介
GRE-动态路由协议实验
IPSec VPN基本概念
IPSec VPN工作原理
IPSec VPN基础实验一(主模式)
GRE Over IPSec实验
计算机网络-L2TP VPN基础概念与原理
L2TP VPN基础实验配置
L2TP Over IPSec基础实验
SSH理论基础
VRF基本概念
MPLS基础概念
MPLS转发原理
MPLS静态标签实验
计算机网络-LDP标签分发协议
LDP工作原理-LDP会话建立
LDP标签发布与管理
VPN实例应用于交换机带外管理接口
H3C V7防火墙IPSECVPN配置(主模式配置)
网络设备拨号设置
网络地址分类与子网划分
防火墙区域以及安全策略配置(命令行版)
H3C V7 IPSEC_VPN配置(野蛮模式配置)
华为_HCIA
路由基础
以太网交换基础
VLAN的原理与配置
VLAN间通信
STP生成树简介
华为VRP系统简介
NAT网络地址转换
ACL访问控制列表
AAA的原理与配置
DHCP配置
链路聚合原理与配置
PPP与PPPoE协议
OSPF路由基础
无线通信基础原理
无线组网基本概念
无线网络配置原理与步骤
典型无线组网实验配置
网络设备防火墙是什么?
防火墙工作原理与安全策略
华为VRP系统基础命令配置
本文档使用 MrDoc 发布
-
+
首页
BFD配置实验
前面我们大致学习了BFD基本原理,包括会话建立的过程、检测模式、检测时间以及检测流程。BFD检测本身不难,但是要看实际应用场景。 ## 一、BFD应用概述 BFD可以实现的功能: - BFD检测IP链路 - BFD单臂回声功能 - BFD与接口状态联动 - BFD与静态路由联动 - BFD与OSPF联动 - BFD与IS-IS联动 - BFD与BGP联动 - BFD与MPLS LSP联动 - BFD与MPLS TE联动 - BFD与VRRP联动 - BFD与PIM联动 配置步骤: 1. 使能全局BFD功能 2. 建立BFD会话(指定对端地址、出接口、源ip、自协商标识符等) 3. 配置BFD检测时间、检测间隔、认证、描述信息(可选) 4. commit提交 ## 二、BFD单跳检测 BFD可以基于二层接口或者三层接口进行检测链路状态。 ### 2.1 基于二层接口的BFD检测 其实我一开始也有疑惑如果是二层接口up/down就直接变化了,那BFD检测是什么意义呢?因为如果只是单纯的接口变化不能关联到相关的上层应用,如路由切换,VRRP切换等,如果有了BFD则会有一个标志开关,BFD状态up标识链路正常,BFD状态down标识链路状态关闭需要进行路由切换操作。  由于二层接口没有IP地址,因为在BFD检测中需要通过模拟生成一个源IP地址发送到组播IP地址中进行BFD状态检测,缺省组播IP地址为:**224.0.0.184** 。 配置: ```ssh # SW1 # 首先全局使能BFD功能,进入BFD视图 bfd # 退出BFD视图 quit # 创建BFD会话,1为会话标识名称,指定对端ip为缺省ip,绑定连接的接口,可选配置源ip bfd 1 bind peer-ip default-ip interface GigabitEthernet0/0/1 discriminator local 1 # 指定本地标识符 discriminator remote 2 # 指定对端标识符,必须双方标识符匹配才能建立BFD会话 commit # 必须通过commit提交配置才会生效 # SW2 # 首先全局使能BFD功能,进入BFD视图 bfd # 退出BFD视图 quit # 创建BFD会话,2为会话标识名称,指定对端ip为缺省ip,绑定连接的接口,可选配置源ip bfd 2 bind peer-ip default-ip interface GigabitEthernet0/0/1 discriminator local 2 # 指定本地标识符,和SW2相反 discriminator remote 1 # 指定对端标识符,必须双方标识符匹配才能建立BFD会话 commit # 必须通过commit提交配置才会生效 ``` 验证BFD会话:`[SW1]display bfd session all verbose `  在SW1的G0/0/1使用shutdown模拟接口故障,缺省在3秒内状态进行切换。  ## 2.2 基于三层接口IP直连检测 通过指定双方的IP地址进行检测。  ```ssh # AR1 # 首先全局使能BFD功能,进入BFD视图 bfd # 退出BFD视图 quit # 创建BFD会话,指定对端地址以及本端出接口,这里可以配置本地源ip或者本地端口都可以 bfd 1 bind peer-ip 10.0.1.2 interface GigabitEthernet0/0/0 discriminator local 2024 # 配置本地标识符 discriminator remote 2024 # 配置对端标识符 commit # 提交 # AR2 # 首先全局使能BFD功能,进入BFD视图 bfd # 退出BFD视图 quit # 创建BFD会话,指定对端地址以及本端出接口,这里可以配置本地源ip或者本地端口都可以 bfd 1 bind peer-ip 10.0.1.1 interface GigabitEthernet0/0/0 discriminator local 2024 # 配置本地标识符 discriminator remote 2024 # 配置对端标识符 min-rx-interval 2000 # 配置接收间隔,检测次数、发送间隔都是在创建会话时配置 commit # 提交 ```  与二层检测不同的就是通过指定对端ip加上本端ip或者本端接口实现检测,配置协商参数也在创建会话时态进行配置。 ## 三、BFD多跳检测 在某些场景在多台非直连设备间进行链路状态检测可以配置BFD多跳检测来实现。 在AR1上与AR3建立BFD多跳会话检测,当AR1到AR3间设备或者链路出现故障则通知BFD,前提是保证IP配置正常,需要在AR1与AR3上配置静态路由到达对方。  配置: ```ssh # AR1 # 全局使能BFD bfd # 配置接口地址 interface GigabitEthernet0/0/0 ip address 10.0.1.1 255.255.255.0 # 创建会话,多跳BFD只需要指定对端IP即可,其它配置与单跳检测一致 bfd 1to3 bind peer-ip 10.0.2.3 discriminator local 1000 discriminator remote 3000 commit # 需要保证路由可达 ip route-static 10.0.2.0 255.255.255.0 10.0.1.2 # AR2 # AR2只需要配置接口地址即可 interface GigabitEthernet0/0/0 ip address 10.0.1.2 255.255.255.0 # interface GigabitEthernet0/0/1 ip address 10.0.2.2 255.255.255.0 # AR3 # 全局使能BFD bfd # 配置接口地址 interface GigabitEthernet0/0/1 ip address 10.0.2.3 255.255.255.0 # 创建会话,指定对端地址 bfd 3to1 bind peer-ip 10.0.1.1 discriminator local 3000 discriminator remote 1000 commit # 保证到达AR1的路由可达 ip route-static 10.0.1.0 255.255.255.0 10.0.2.2 ```  可以在AR2的G0/0/1接口shudown模拟中间设备故障。 ```ssh # AR2 interface GigabitEthernet0/0/1 shutdown ip address 10.0.2.2 255.255.255.0 ```  多跳检测相比于单跳检测区别在于不知道本端信息,只需要知道对端地址即可,依赖于路由协议。 ## 四、BFD单臂回声检测 在某些场景下老旧设备可能不支持BFD,这时候可以采用单臂回声方式进行检测。  AR1与AR2保证可达即可,在AR1上创建BFD会话,单臂回声只支持指定本端出接口,而且只需要指定本地标识符。 配置: ```ssh # AR1 # 全局使能BFD bfd # 配置接口地址 interface GigabitEthernet0/0/0 ip address 10.0.1.1 255.255.255.0 # 指定对端ip和本端出接口,后面加上one-arm-echo参数 bfd one-arm bind peer-ip 10.0.1.2 interface GigabitEthernet0/0/0 one-arm-echo discriminator local 1111 # 只需要指定本地标识符 min-echo-rx-interval 2000 # 可以配置发送报文的间隔 commit # 提交 # AR2 interface GigabitEthernet0/0/0 ip address 10.0.1.2 255.255.255.0 ```  单臂回声检测用于一方不支持或者没有配置的情况下,双方网络层能够互通,只需要指定对端ip和本地出接口,添加one-arm-echo参数。 ## 五、BFD联动功能 上面我们讲了怎样建立BFD会话,但是实际意义不大,因为即使BFD会话状态up/down也不会有什么影响,只有将BFD与应用进行绑定联动才能真正发挥作用。 ### 5.1 静态路由绑定BFD  在AR1访问AR4上的4.4.4.4,通过配置默认路由分别走AR2和AR3,正常情况下优先走AR2,设置AR3的路由优先级为100。AR2和AR3分别配置去往4.4.4.4/32的路由,AR4分别配置缺省路由指向AR2、AR3。 配置BFD之前: ```ssh # AR1 # 配置接口地址 interface GigabitEthernet0/0/0 ip address 10.0.1.1 255.255.255.0 # interface GigabitEthernet0/0/1 ip address 10.0.2.1 255.255.255.0 # 配置缺省路由,优先走AR2,当AR2失效时走AR3 ip route-static 0.0.0.0 0.0.0.0 10.0.1.2 ip route-static 0.0.0.0 0.0.0.0 10.0.2.3 preference 100 # AR2 # 配置接口地址 interface GigabitEthernet0/0/0 ip address 10.0.1.2 255.255.255.0 # interface GigabitEthernet0/0/1 ip address 10.0.3.2 255.255.255.0 # 配置去往4.4.4.4/32的路由指向AR4 ip route-static 4.4.4.4 255.255.255.255 10.0.3.4 # AR3 # 接口配置 interface GigabitEthernet0/0/0 ip address 10.0.4.3 255.255.255.0 # interface GigabitEthernet0/0/1 ip address 10.0.2.3 255.255.255.0 # 路由配置 ip route-static 4.4.4.4 255.255.255.255 10.0.4.4 # AR4 # 接口配置 interface GigabitEthernet0/0/0 ip address 10.0.4.4 255.255.255.0 # interface GigabitEthernet0/0/1 ip address 10.0.3.4 255.255.255.0 # interface GigabitEthernet0/0/2 # interface LoopBack0 ip address 4.4.4.4 255.255.255.255 # 路由配置 ip route-static 0.0.0.0 0.0.0.0 10.0.3.2 ip route-static 0.0.0.0 0.0.0.0 10.0.4.3 ``` 缺省情况下浮动路由也会进行切换但是时间比较长,现在在AR2的G0/0/0口shutdown模拟AR1与AR2故障,查看路由切换现象。  在AR1和AR2创建BFD会话,绑定BFD。 ```ssh # AR1 # 使能BFD bfd # 创建一个单跳BFD bfd 1 bind peer-ip 10.0.1.2 interface GigabitEthernet0/0/0 discriminator local 1 discriminator remote 2 min-tx-interval 100 # 最小发送间隔 min-rx-interval 100 # 最小接收间隔 commit # 提交 # 使用track将BFD和静态路由进行关联 undo ip route-static 0.0.0.0 0.0.0.0 10.0.1.2 ip route-static 0.0.0.0 0.0.0.0 10.0.1.2 track bfd-session 1 # AR2 # 使能BFD bfd # 创建BFD会话 bfd 1 bind peer-ip 10.0.1.1 interface GigabitEthernet0/0/0 discriminator local 2 discriminator remote 1 min-tx-interval 100 min-rx-interval 100 commit ```   大致的过程如下,当AR2的G0/0/0接口故障后,在300ms后BFD会话状态变为down,然后通过track模块关联到静态路由,静态路由进行切换到备份路由实现快速切换。 ### 5.2 OSPF绑定BFD检测 这里BFD用于OSPF主要用于故障的快速收敛,也就是接口donw了尽快把邻居状态变更,把路由进行切换。缺省情况下OSPF通过周期发送hello包(10秒)进行邻居间状态检测,然后dead时间是(40秒),会将路由删除。这就可能导致在接口发生故障时在秒级故障无法进行切换。  配置: ```ssh # AR1 # 全局使能BFD bfd # 接口配置 interface GigabitEthernet0/0/0 ip address 10.0.1.1 255.255.255.0 # interface GigabitEthernet0/0/1 ip address 10.0.2.1 255.255.255.0 # 创建OSPF进程 ospf 1 bfd all-interfaces enable #所有ospf接口使能bfd bfd all-interfaces min-tx-interval 100 min-rx-interval 100 # 配置最小发送和接收间隔为100毫秒 area 0.0.0.0 network 10.0.1.0 0.0.0.255 network 10.0.2.0 0.0.0.255 # 其它路由器配置一致,这里不重复了。 ``` 通过`dis ospf bfd session all`命令查看。  通过`dis bfd session all verbose`查看BFD详细信息。  实现的效果其实看不太出来,就是正常情况下如果接口故障需要等待hello超时然后邻居才会断开,然后删除相关路由表项。关联BFD后如果BFD状态变更则直接进行切换,保持在毫秒级。但是对于重新建立OSPF邻居还是按照原有流程经过**init-2-way-exstart-exchange-full**状态。 ## 六、常用配置命令 ```ssh # 全局启用BFD bfd # 创建BFD会话绑定信息,并进入BFD会话视图 [Huawei] bfd session-name bind peer-ip ip-address [ vpn-instance vpn-name ] interface interface-type interface-number [ source-ip ip-address ] # 二层BFD检测,使用组播地址进行创建BFD会话 [Huawei] bfd session-name bind peer-ip default-ip interface interface-type interface-number [ source-ip ip-address ] # 创建单臂Echo功能的BFD会话,添加参数one-arm-echo [Huawei] bfd session-name bind peer-ip ip-address [ vpn-instance vpn-name ] interface interface-type interface-number [ source-ip ip-address ] one-arm-echo # 配置BFD会话的本地标识符,进入BFD会话视图后配置 [Huawei-bfd-session-test] discriminator local discr-value # 配置BFD会话的远端标识符 [Huawei-bfd-session-test] discriminator remote discr-value # 配置最小发送间隔 min-tx-interval [10-2000]ms # 配置最小接收间隔 min-rx-interval [10-2000]ms # 配置检测间隔次数 detect-multiplier [3-50] # 提交确认配置,只有commit之后配置才会生效 commit # 手动关闭BFD会话 shutdown # 查看bfd会话简要信息 display bfd session all # 查看详细信息 display bfd session all verbose ``` 总结:学习了静态创建BFD以及通过OSPF动态创建BFD会话,可以创建BFD实现单跳或者多跳检测以及使用单臂回声功能在一些不支持BFD的设备间进行检测,最后可以通过track模块关联静态路由和动态路由协议,实现毫秒级别的故障切换。
Chuck
2024年8月19日 16:54
转发文档
收藏文档
上一篇
下一篇
手机扫码
复制链接
手机扫一扫转发分享
复制链接
Markdown文件
分享
链接
类型
密码
更新密码