华为设备配置VRRP主备备份案例

华为设备配置VRRP主备备份案例

组网拓扑:

VRRP主备备份简介

通常,同一网段内的所有主机上都存在一条相同的、以网关为下一跳的缺省路由。主机发往其他网段的报文将通过缺省路由发往网关,再由网关进行转发,从而实现主机与外部网络的通信。当网关发生故障时,本网段内所有以网关为缺省路由的主机将无法与外部网络通信。增加出口网关是提高系统可靠性的常见方法,此时如何在多个出口之间进行选路就成为需要解决的问题。

VRRP的出现很好的解决了这个问题。VRRP能够在不改变组网的情况下,采用将多台路由设备组成一个虚拟路由器,通过配置虚拟路由器的IP地址为默认网关,实现默认网关的备份。当网关设备发生故障时,VRRP机制能够选举新的网关设备承担数据流量,从而保障网络通信的可靠性。

在配置VRRP备份组内各交换机时,建议将Backup配置为立即抢占,即不延迟(延迟时间为0),而将Master配置为延时抢占,并且配置15秒以上的延迟时间。这样配置的目的是为了在网络环境不稳定时,在上下行链路的状态恢复一致性期间等待一定时间,避免由于双方频繁抢占导致用户设备学习到错误的Master设备地址而导致流量中断问题。

  • 抢占模式:在抢占模式下,如果Backup设备的优先级比当前Master设备的优先级高,则主动将自己切换成Master。
  • 非抢占模式:在非抢占模式下,只要Master设备没有出现故障,Backup设备即使随后被配置了更高的优先级也不会成为Master设备。

组网需求

如拓扑所示,HostA通过Switch双归属到SwitchA和SwitchB。为保证用户的各种业务在网络传输中不中断,需在SwitchA和SwitchB上配置VRRP主备备份功能。

  • 正常情况下,主机以SwitchA为默认网关接入Internet,当SwitchA故障时,SwitchB接替SwitchA作为网关继续进行工作,实现网关的冗余备份。
  • SwitchA故障恢复后,其延时20秒通过抢占的方式重新成为Master,承担数据传输。

配置思路

采用VRRP主备备份实现网关冗余备份,配置思路如下:

  1. 配置各设备接口IP地址及路由协议,使各设备间网络层连通。
  2. 在SwitchA和SwitchB上配置VRRP备份组。其中,SwitchA上配置较高优先级和20秒抢占延时,作为Master设备承担流量转发;SwitchB上配置较低优先级,作为备用交换机,实现网关冗余备份。

操作步骤

  1. 配置设备间的网络互连

配置设备各接口的IP地址,以SwitchA为例。SwitchB和SwitchC的配置与SwitchA类似,详见配置文件。

复制代码
<HUAWEI> system-view
复制代码
[HUAWEI] sysname SwitchA
复制代码
[SwitchA] vlan batch 100 300
复制代码
[SwitchA] interface gigabitethernet 1/0/1
复制代码
[SwitchA-GigabitEthernet1/0/1] port link-type hybrid
复制代码
[SwitchA-GigabitEthernet1/0/1] port hybrid pvid vlan 300
复制代码
[SwitchA-GigabitEthernet1/0/1] port hybrid untagged vlan 300
复制代码
[SwitchA-GigabitEthernet1/0/1] quit
复制代码
[SwitchA] interface gigabitethernet 1/0/2
复制代码
[SwitchA-GigabitEthernet1/0/2] port link-type hybrid
复制代码
[SwitchA-GigabitEthernet1/0/2] port hybrid pvid vlan 100
复制代码
[SwitchA-GigabitEthernet1/0/2] port hybrid untagged vlan 100
复制代码
[SwitchA-GigabitEthernet1/0/2] quit
复制代码
[SwitchA] interface vlanif 100
复制代码
[SwitchA-Vlanif100] ip address 10.1.1.1 24
复制代码
[SwitchA-Vlanif100] quit
复制代码
[SwitchA] interface vlanif 300
复制代码
[SwitchA-Vlanif300] ip address 192.168.1.1 24
复制代码
[SwitchA-Vlanif300] quit

配置Switch的二层转发功能。

复制代码
<HUAWEI> system-view
复制代码
[HUAWEI] sysname Switch
复制代码
[Switch] vlan 100
复制代码
[Switch-vlan100] quit
复制代码
[Switch] interface gigabitethernet 1/0/1
复制代码
[Switch-GigabitEthernet1/0/1] port link-type hybrid
复制代码
[Switch-GigabitEthernet1/0/1] port hybrid pvid vlan 100
复制代码
[Switch-GigabitEthernet1/0/1] port hybrid untagged vlan 100
复制代码
[Switch-GigabitEthernet1/0/1] quit
复制代码
[Switch] interface gigabitethernet 1/0/2
复制代码
[Switch-GigabitEthernet1/0/2] port link-type hybrid
复制代码
[Switch-GigabitEthernet1/0/2] port hybrid pvid vlan 100
复制代码
[Switch-GigabitEthernet1/0/2] port hybrid untagged vlan 100
复制代码
[Switch-GigabitEthernet1/0/2] quit

配置SwitchA、SwitchB和SwitchC间采用OSPF协议进行互连。以SwitchA为例,SwitchB和SwitchC的配置与SwitchA类似,详见配置文件。

复制代码
[SwitchA] ospf 1
复制代码
[SwitchA-ospf-1] area 0
复制代码
[SwitchA-ospf-1-area-0.0.0.0] network 10.1.1.0 0.0.0.255
复制代码
[SwitchA-ospf-1-area-0.0.0.0] network 192.168.1.0 0.0.0.255
复制代码
[SwitchA-ospf-1-area-0.0.0.0] quit
复制代码
[SwitchA-ospf-1] quit
  1. 配置VRRP备份组

在SwitchA上创建VRRP备份组1,配置SwitchA在该备份组中的优先级为120,并配置抢占时间为20秒。

复制代码
[SwitchA] interface vlanif 100
复制代码
[SwitchA-Vlanif100] vrrp vrid 1 virtual-ip 10.1.1.111
复制代码
[SwitchA-Vlanif100] vrrp vrid 1 priority 120                  //设备在VRRP备份组中的优先级缺省为100,修改Master设备的优先级大于Backup设备
复制代码
[SwitchA-Vlanif100] vrrp vrid 1 preempt-mode timer delay 20   //设备在VRRP备份组中缺省采用立即抢占方式。修改Master设备的延迟抢占时间,以避免在网络环境不稳定时,由于双方频繁抢占而导致流量中断的问题
复制代码
[SwitchA-Vlanif100] quit

在SwitchB上创建VRRP备份组1,其在该备份组中的优先级采用缺省值100(不需要配置)。

复制代码
[SwitchB] interface vlanif 100
复制代码
[SwitchB-Vlanif100] vrrp vrid 1 virtual-ip 10.1.1.111
复制代码
[SwitchB-Vlanif100] quit
  1. 验证配置结果

完成上述配置以后,在SwitchA和SwitchB上分别执行display vrrp命令,可以看到SwitchA在备份组中的状态为Master,SwitchB在备份组中的状态为Backup。

复制代码
[SwitchA] display vrrp
复制代码
  Vlanif100 | Virtual Router 1
复制代码
    State : Master
复制代码
    Virtual IP : 10.1.1.111
复制代码
    Master IP : 10.1.1.1
复制代码
    PriorityRun : 120
复制代码
    PriorityConfig : 120                                                        
复制代码
    MasterPriority : 120                                                        
复制代码
    Preempt : YES   Delay Time : 20 s
复制代码
    TimerRun : 1 s
复制代码
    TimerConfig : 1 s
复制代码
    Auth type : NONE                                                            
复制代码
    Virtual MAC : 0000-5e00-0101                                                
复制代码
    Check TTL : YES                                                             
复制代码
    Config type : normal-vrrp                                                   
复制代码
    Backup-forward : disabled
复制代码
[SwitchB] display vrrp
复制代码
  Vlanif100 | Virtual Router 1
复制代码
    State : Backup
复制代码
    Virtual IP : 10.1.1.111
复制代码
    Master IP : 10.1.1.1
复制代码
    PriorityRun : 100
复制代码
    PriorityConfig : 100                                                        
复制代码
    MasterPriority : 120                                                        
复制代码
    Preempt : YES   Delay Time : 0 s
复制代码
    TimerRun : 1 s
复制代码
    TimerConfig : 1 s
复制代码
    Auth type : NONE                                                            
复制代码
    Virtual MAC : 0000-5e00-0101                                                
复制代码
    Check TTL : YES                                                             
复制代码
    Config type : normal-vrrp                                                   
复制代码
    Backup-forward : disabled

在SwitchA和SwitchB上执行display ip routing-table命令,SwitchA上可以看到路由表中有一条目的地址为虚拟IP地址的直连路由,而SwitchB上该路由为OSPF路由。SwitchA和SwitchB上的显示信息如下。

复制代码
[SwitchA] display ip routing-table
复制代码
Route Flags: R - relay, D - download to fib, T - to vpn-instance
复制代码
------------------------------------------------------------------------------  
复制代码
Routing Tables: Public                                                          
复制代码
         Destinations : 9       Routes : 10                                                                                                                    
复制代码
Destination/Mask    Proto   Pre  Cost      Flags NextHop         Interface                                                                                      
复制代码
10.1.1.0/24    Direct   0     0         D      10.1.1.1        Vlanif100
复制代码
10.1.1.1/32    Direct   0     0         D      127.0.0.1       Vlanif100
复制代码
10.1.1.111/32  Direct   0     0         D      127.0.0.1       Vlanif100
复制代码
127.0.0.0/8    Direct   0    0          D      127.0.0.1       InLoopBack0
复制代码
127.0.0.1/32   Direct   0    0          D      127.0.0.1       InLoopBack0
复制代码
172.16.1.0/24    OSPF     10   2          D      192.168.1.2     Vlanif300
复制代码
192.168.1.0/24    Direct   0    0          D     192.168.1.1     Vlanif300
复制代码
192.168.1.1/32    Direct   0    0          D     127.0.0.1       Vlanif300
复制代码
192.168.2.0/24    OSPF     10   2          D     10.1.1.2        Vlanif100
复制代码
                  OSPF     10   2          D     192.168.1.2     Vlanif300
复制代码
[SwitchB] display ip routing-table
复制代码
Route Flags: R - relay, D - download to fib, T - to vpn-instance
复制代码
------------------------------------------------------------------------------  
复制代码
Routing Tables: Public                                                          
复制代码
         Destinations : 9       Routes : 10                                                                                                                    
复制代码
Destination/Mask    Proto   Pre  Cost      Flags NextHop         Interface                                                                                    
复制代码
10.1.1.0/24    Direct   0     0         D     10.1.1.2        Vlanif100
复制代码
10.1.1.2/32    Direct   0     0         D     127.0.0.1       Vlanif100
复制代码
10.1.1.111/32    OSPF    10    2         D     10.1.1.1       Vlanif100
复制代码
127.0.0.0/8    Direct   0     0         D     127.0.0.1       InLoopBack0
复制代码
127.0.0.1/32    Direct   0     0         D     127.0.0.1       InLoopBack0
复制代码
172.16.1.0/24    OSPF     10    2         D     192.168.2.2     Vlanif200
复制代码
192.168.1.0/24    OSPF     10    2         D     10.1.1.1        Vlanif100
复制代码
                  OSPF     10    2         D     192.168.2.2     Vlanif200
复制代码
192.168.2.0/24    Direct   0     0         D     192.168.2.1     Vlanif200
复制代码
192.168.2.1/32    Direct   0     0         D     127.0.0.1       Vlanif200

在SwitchA的接口GE1/0/2上执行shutdown命令,模拟SwitchA出现故障。

复制代码
[SwitchA] interface gigabitethernet 1/0/2
复制代码
[SwitchA-GigabitEthernet1/0/2] shutdown
复制代码
[SwitchA-GigabitEthernet1/0/2] quit

在SwitchB上执行display vrrp命令查看VRRP状态信息,可以看到SwitchB的状态是Master。

复制代码
[SwitchB] display vrrp
复制代码
  Vlanif100 | Virtual Router 1
复制代码
    State : Master
复制代码
    Virtual IP : 10.1.1.111
复制代码
    Master IP : 10.1.1.2
复制代码
    PriorityRun : 100
复制代码
    PriorityConfig : 100                                                        
复制代码
    MasterPriority : 100                                                        
复制代码
    Preempt : YES   Delay Time : 0 s
复制代码
    TimerRun : 1 s
复制代码
    TimerConfig : 1 s
复制代码
    Auth type : NONE                                                            
复制代码
    Virtual MAC : 0000-5e00-0101                                                
复制代码
    Check TTL : YES                                                             
复制代码
    Config type : normal-vrrp                                                   
复制代码
    Backup-forward : disabled

在SwitchA的接口GE1/0/2上执行undo shutdown命令。

复制代码
[SwitchA] interface gigabitethernet 1/0/2
复制代码
[SwitchA-GigabitEthernet1/0/2] undo shutdown
复制代码
[SwitchA-GigabitEthernet1/0/2] quit

等待20秒后,在SwitchA上执行display vrrp命令查看VRRP状态信息,可以看到SwitchA的状态恢复成Master。

复制代码
[SwitchA] display vrrp
复制代码
  Vlanif100 | Virtual Router 1
复制代码
    State : Master
复制代码
    Virtual IP : 10.1.1.111
复制代码
    Master IP : 10.1.1.1
复制代码
    PriorityRun : 120
复制代码
    PriorityConfig : 120                                                        
复制代码
    MasterPriority : 120                                                        
复制代码
    Preempt : YES   Delay Time : 20 s
复制代码
    TimerRun : 1 s
复制代码
    TimerConfig : 1 s
复制代码
    Auth type : NONE                                                            
复制代码
    Virtual MAC : 0000-5e00-0101                                                
复制代码
    Check TTL : YES                                                             
复制代码
    Config type : normal-vrrp                                                   
复制代码
    Backup-forward : disabled
相关推荐
zhaowangji几秒前
ubuntu虚拟机装载共享文件夹导致的诡异错误
linux·运维·ubuntu
张望远-长风万里2 分钟前
运维监控专项学习笔记-id:0-需求场景、监控作用、监控能力
运维·笔记·学习
小崔爱读书3 分钟前
普元DWS - Linux下安装DWS标准版
linux·运维·服务器
学java的小菜鸟啊13 分钟前
第五章 网络编程 TCP/UDP/Socket
java·开发语言·网络·数据结构·网络协议·tcp/ip·udp
&星辰入梦来&16 分钟前
Nginx从入门到入土(三): 静态资源管理与代理服务
运维·nginx·负载均衡
新手嵌入式学习40 分钟前
网络协议头分析
网络·网络协议
小安运维日记1 小时前
Linux云计算 |【第三阶段】PROJECT1-DAY1
linux·运维·云计算·apache
pyliumy1 小时前
rsync 全网备份
linux·运维·服务器
苹果醋31 小时前
SpringCloud系列之一---搭建高可用的Eureka注册中心
运维·nginx
诚诚k1 小时前
docker存储
运维·docker·容器