Linux 下VRF的简单应用

1,引入

VRF是实现虚拟路由转发功能的,在linux-4.0内核以上实现的,vrf的实际功能是实现了3层的数据包的隔离,这跟VLAN实现的二层隔离是不一样的。下面主要介绍LINUX下VRF的创建(ip命令)和结合一些应用相关使用VRF。

https://blog.csdn.net/dog250/article/details/78069964 这篇博客原理性的东西讲的很好,可以参考。

2,VRF接口的创建

① 创建一个VRF red并绑定路由表table 10:

复制代码
ip link add red type vrf table 10
ip link set red up  (up接口)

我们可以看到一个red接口和ip rule下看到三层设备:

:不管添加了几个vrf设备,在ip rule下只会看到一个[l3mdev-table],可以理解为这只是一个入口。

② 向当前vrf red中增加或删除接口

复制代码
ip link set dev eth0.1 master red :把eth0.1加入red中
ip link set dev eth0.1 nomaster   :删除eth0.1接口

注意:为什么删除的时候不用带red参数?

因为一个接口只能被添加到一个vrf中,如果多次添加,只有最后一个生效。

③ 显示当前的vrf 信息:

复制代码
ip vrf show : 显示所有vrf 与 table 表绑定关系
ip vrf show red : 显示vrf red 信息

④ 其他显示命令 (只需要在对应的IP命令后面带上vrf red)

复制代码
ip link show vrf red  :显示接口
ip route show vrf red :显示路由
ip addr show vrf red  :显示地址
ip neigh show vrf red :显示邻居

⑤ route和addr添加

复制代码
ip addr add 172.10.10.10/24 dev eth0.1 :添加addr
ip route add 192.168.1.0/24 via 172.10.10.11 vrf red :添加路由

因为red中绑定的table 10,所以路由也可以向table 10添加

⑥ 测试命令

ip vrf exec red ping 10.10.10.101 :连通性测试(ping可以替换为其他的命令,需要内核开启cgroup CONFIG_CGROUP_DEVICE)

如何让应用程序绑定你的vrf接口哪?

① 使用 ip vrf exec [red] [cmd] : 用对应的vrf启动相关的命令程序,这通常可以使用在独立的程序启动,如果这个程序全局都要使用,则不要这样做,除非这个程序可以启动多次。

② 通过 setsockopt去将程序的套接字绑定到对应的vrf域中

setsockopt(nSock, SOL_SOCKET, SO_BINDTODEVICE, vrf_name, strlen(vrf_name)+1)

3,绑定的应用程序

① 动态路由协议使用frr版本的,原生支持vrf接口的绑定(rip ospf bgp等)

4,总结

以上简单介绍了vrf的使用,其实功能性的东西就这么多,主要是如何结合其他应用程序,实现相关的隔离功能,其次就是隔离后的vrf域和全局的网络空间之间有什么区别和联系,这些是需要我们观察的。

相关推荐
野生工程师17 小时前
【Linux基础-2】Linux的基本指令
linux·运维·windows
Amarone17 小时前
Uptime Kuma 部署安装运维手册
运维·uptime kuma
weixin_3954489117 小时前
mult_yolov5_post_copy.c_cursor
linux·人工智能·python
昨夜见军贴061617 小时前
IACheck AI审核推动质量控制记录标准化,全面保障含量测定研究合规性
大数据·运维·人工智能
venus6017 小时前
服务器里面多个网口,电口,光口如何区分使用
运维·服务器
猫猫的小茶馆17 小时前
【Linux 驱动开发】一. 搭建开发环境
linux·汇编·arm开发·驱动开发·stm32·嵌入式硬件·mcu
zhojiew17 小时前
关于envoy的基础概念组件构成和示例配置笔记整理
服务器·网络
A-刘晨阳17 小时前
ubuntu各版本配置apt源(阿里源)
linux·运维·ubuntu
Trouvaille ~17 小时前
【Linux】进程间通信(一):IPC基础与管道机制深度剖析
linux·运维·c++·管道·进程间通信·匿名管道·半双工
prettyxian17 小时前
【linux】进程地址空间与虚拟内存机制
linux·运维·服务器