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域和全局的网络空间之间有什么区别和联系,这些是需要我们观察的。

相关推荐
云栖梦泽2 小时前
Linux内核与驱动:14.SPI子系统
linux·运维·服务器·c++
福大大架构师每日一题2 小时前
openclaw v2026.4.24 发布:Google Meet 深度集成、DeepSeek V4 上线、浏览器自动化与插件架构全面升级
运维·架构·自动化·openclaw
yipiantian3 小时前
在Claude项目中实现跨目录访问Skills
linux·运维·服务器
Agent产品评测局3 小时前
生产排期与MES/ERP系统打通,实操方法详解 —— 2026企业级智能体自动化选型与实战指南
java·运维·人工智能·ai·chatgpt·自动化
cen__y3 小时前
Linux07(信号01)
linux·运维·服务器·c语言·开发语言
MT5开发3 小时前
Linux安装MariaDB
linux·运维·mariadb
Lentou3 小时前
日志轮询策略
linux·服务器·网络
Yoyo25年秋招冲冲冲4 小时前
【亲测可用】ubuntu系统下安装Openclaw+配置飞书
linux·ubuntu·ai·飞书·openclaw
你好,帅哥4 小时前
openssl ,msys2 ,交叉编译
linux·运维·服务器
计算机安禾4 小时前
【Linux从入门到精通】第36篇:DNS服务探秘——自己搭建一个内网DNS
linux·运维·servlet