上篇文章介绍了Open vSwitch 的基本功能,这篇将介绍OVS 实现的隧道协议GRE 和 VXLAN。首先,我们再看看OVS 的datapath 。
数据路径(datapath)
OVS的核心组件包括 ovsdb-server,ovs-vswitchd,ovs kernel module。
内核模块实现了多个数据路径(datapath) (类似于网桥),每个数据路径都可以有多个 vports (类似于桥内的端口)。每个数据路径也通过关联流表(flow table)来设置操作,而这些流表中的流都是用户空间在报文头和元数据的基础上映射的关键信息,一般的操作都是将数据包转发到另一个vport。
当一个数据包到达一个vport,内核模块所做的处理是提取其流的关键信息并在流表中查找这些关键信息。当有一个匹配的流时它执行对应的操作。如果没有匹配,它会将数据包送到用户空间的处理队列中(作为处理的一部分,用户空间可能会设置一个流用于以后遇到相同类型的数据包可以在内核中执行操作)
前面的实验比较简单,后面隧道协议的使用,需要查看官方的功能兼容列表。
这里提到 Open vSwitch 在不同的平台支持不同的数据路径。不同的数据路径支持不同的功能集合。
目前之前4种数据路径:
- Linux upstream:通过上游Linux 内核自带的内核模块实现的datapath。由于openvswitch 功能已经引入内核,可以根据不同发行版Linux 的内核版本查看支持的功能。
- Linux OVS tree:通过OVS 源代码生成的内核模块实现的。
- Userspace: 也称为DPDK,dpif-netdev 或者dummy datapath。这是NetBSD,FreeBSD 和Mac OSX 仅支持的数据路径。
- Hyper-V:Windows 平台的数据路径。
下面是不同的数据路径可以实现的功能。
Linux OVS tree
这里使用CentOS 7.2 原生的内核 3.10 版本,要实现GRE和VXLAN,则需要使用 Linux OVS tree 数据路径。实验中需要重新打包Open vSwitch。重新安装的过程如下:
删除原来的ovs 配置,卸载openvswitch
ovs-vsctl del-br br0
systemctl stop openvswitch
yum remove –y openvswitch
安装新的依赖包
yum install rpm-build autoconf automake libtool systemd-units openssl openssl-devel python python-twisted-core python-zope