VRF (Virtual Routing and Forwarding)使同一系统下拥有多种且独立的路由表。在LINUX的内核中,从4.3版本已开始支持VRF,若需要较好支持vrf功能,建议Linux操作系统内核版本4.8以上。
- 操作环境:本文操作系统采用CentOS8,已经安装iproute2。
如下将创建一个veth对,并将其分别绑定到两个不同VRF,然后互相ping通IP;
1. VETH打通不同VRF的基础配置
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
# 1.创建vrf表red和blue并分别启动 ip link add blue type vrf table 1 ip link add red type vrf table 2 ip link set blue up ip link set red up ip link show type vrf # 2.创建veth对red1和blue1,并分别挂载到对应vrf,启动 ip link add red1 type veth peer name blue1 ip link set red1 vrf red ip link set blue1 vrf blue ip link set blue1 up ip link set red1 up # 3.给veth对分配ip,并ping通彼此 ip addr add 10.10.10.1/24 dev red1 ip addr add 10.10.10.2/24 dev blue1 # 4.通过VRF进行ping操作 ping 10.10.10.1 -I blue1 ping 10.10.10.2 -I red1 |
1 2 3 4 |
# 查看vrf blue的端口地址和路由 ip link show vrf blue ip addr show vrf blue ip route show vrf blue |
2. 打通VPP->Linux Kernel netns途径
2.1. linux Shell创建vrf和一对veth,并进行设置;
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
#创建并启动vrf ip link add vrf-2 type vrf table 2 ip link set vrf-2 up #创建veth并绑定 ip link add vpp2 type veth peer name frr2 ip link set frr2 up ip link set vpp2 up ip link set frr2 vrf vrf-2 #添加veth pair的IP ip addr add 10.10.40.1/24 dev frr2 #添加静态路由到vrf表中,指向vpp中网段 ip route add 10.10.10.0/24 via 10.10.40.2 dev frr2 vrf vrf-2 |
2.2. vpp中接管VETH网卡
1 2 3 4 5 6 7 8 9 10 11 12 13 |
#vppctl #创建vrf表2,并挂载物理口G2 ip table add 2 set int ip table G2 2 set interface state G2 up set interface ip addr G2 10.10.10.1/24 #接管veth 网卡 create host-interface name vpp2 set int ip table host-vpp2 2 set interface state host-vpp2 up set interface ip addr host-vpp2 10.10.40.2/24 #添加静态路由,指向vrf 2直连端口下一跳 ip route add 10.10.10.0/24 table 2 via G2 |
3. 打通FRR->Linux Kernel netns途径
通过FRR官方文档可知,Frr中模块zebra支持对操作系统底层网络的多个接口、地址、静态路由、VRF的动态同步;也可通过配置/etc/frr/zebra.conf完成指定VRF,启动时加-f /etc/frr/zebra.conf;这种情况下,不需要在daemons配置文件中开启-n参数。
微信赞赏
支付宝赞赏