OVS DB介绍及在OpenDaylight中的调用

本文深入探讨了Open vSwitch(OVS)及其与OpenDaylight(ODL)的集成,详细介绍了OVS的组件、架构及OVSDB管理协议。同时,文章还讲解了如何在ODL中使用OVSDB南向插件,包括被动和主动连接方式的配置与测试。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

OVS是一种开源的软件交换机,可安装于通用的虚拟服务器环境中,在虚拟环境中单个、多个物理机上的不同虚拟主机都需要通过OVS实现数据交换。

 

 

OVS包含三个重要的组件:ovsdb-server、ovs-vswitchd、以及OVS内核模块,
ovsdb-server:OVS的数据库服务进程,用于存储虚拟交换机的配置信息(比如网桥、端口等),为控制器和ovs-vswitchd提供OVSDB操作接口。
ovs-vswitchd:OVS的核心组件,负责保存和管理控制器下发的所有流表,为OVS的内核模块提供流表查询功能,并为控制器提供OpenFlow协议的操作接口。
OVS内核模块:缓存某些常用流表,并负责数据包转发,当遇到无法匹配的报文,该模块将向ovs-vswitchd发送pack-in请求,获取报文处理指令。
其架构为:

OVS提供的命令:

  • ovs-dpctl 管理OVS内核模块,提供缓存流表的操作方法
  • ovs-vsctl 管理ovsdb-server的配置,提供OVSDB的配置方法,包括创建和删除网桥、端口等
  • ovs-appctl 管理ovs-vswitchd的日志输出
  • ovs-ofctl 管理ovs-vswitchd的流表配置方法
  • ovs-pki 创建和管理公钥
  • ovs-tcpundump 抓取并解析OpenFlow消息
  • ovsdb-tool 创建和管理ovsdb

一、OVSDB介绍

开放虚拟交换机数据库(OpenvSwitch Database,OVSDB)是开放虚拟交换机中保存的各种配置信息(如网桥、端口)的数据库,是针对OpenvSwitch开发的轻量级数据库。
OVSDB数据库由两个主要部分构成,即ovsdb-server和ovsdb-client,Ovsdb-server是OVS的数据库服务器端,位于Open vSwitch本地。Ovsdb-client则为OVS数据库客户端,其通过OVSDB 管理协议(Open vSwitch Database Management Protocol)向ovsdb-server端发送数据库配置和查询的命令,即ovs-vsctl命令。因此,ovs-client又被称为管理者。ovsdb-client通常运行在Open vSwitch 本地,即管理员可以在OVS本地以命令行方式输入数据库配置和查询命令。另外,ovsdb-client也可以部署在远端,从而实现对ovsdb-server的远程配置。目前在Opendaylight控制器中也有一个单独的子项目实现此管理协议,即OVSDB(比如ovsdb-release-lithium-sr3)。
OVSDB是一个轻量级的数据库,其实它只是一个JSON文件,默认路径为/etc/openvswitch/conf.db。记录的网桥、端口、QOS等网络配置信息是以JSON格式(schema)保存的,通常schema在/usr/share/openvswitch/vswitch.ovsschema中。

1.1 OVSDB管理协议

OVSDB管理协议(OVSDB management protocol)是VMware公司提出的负责管理OVS数据库的协议,OVSDB管理协议定义了一套RPC接口,用户可通过远程调用的方式管理OVSDB。

其中transact是OVSDB管理协议中比较重要的操作方法,它是RPC请求的参数中提供数据库的增、删、改、查等常用操作:

二、ODL中的OVSDB插件

ODL中包括三个OVSDB插件,OVSDB southbound、northbound、openstack,他们的逻辑关系如下图所示:

2.1 OVSDB的不兼容性

These 2 ovsdb features cannot be installed at the same time: odl-ovsdb-plugin and odl-ovsdb-southbound-impl that is so, because they will instantiate their own ovsdb-library, which listens on port 6640 (by default).
When odl-ovsdb-openstack is used, it assumes no other application in odl is managing network-virt. In other words, it is assumed that if ovsdb is using odl-neutron-service, no other feature in odl is providing the same net-virt service.

2.2 OVSDB南向插件的使用

1、安装南向插件

Shell

 

1

2

feature:install odl-ovsdb-southbound-impl-ui

log:display  | grep SouthboundProvider   //查看是否已安装好

ovsdb插件的被动连接方式下(也就是控制器的ovsdb插件当做服务器,设备当做客户端),md-sal de operational 数据库的OVS的node-id格式为ovsdb://uuid//{{uuid of OVS}};主动连接模式下,OVS的node-id格式为 ovsdb: //{{ip : port}}

2、测试ovsdb插件的被动连接方式,在终端运行

Shell

 

1

2

ovs-vsctl set-manager tcp:192.168.7.103:6640      //192.168.7.103是控制器的IP

curl -u admin:admin http://localhost:8181/restconf/operational/network-topology:network-topology/

通过curl能够看到ovsdb节点信息。

Shell

 

1

2

ovs-vsctl del-manager  删除连接

ovs-vsctl add-br br01    增加br01 桥

3、测试ovsdb插件的主动连接方式,在终端运行

Shell

 

1

2

ovs-vsctl set-manager ptcp:6640

ovs-vsctl show  可以看到ovsdb在监听控制器的连接(设备是服务器)


此时通过postman设置odl控制器来连接ovsdb:


可以通过web看到:

参考资料

OpenDaylight OVSDB架构:
https://wiki.opendaylight.org/view/OVSDB:Developer_Guide#OpenDaylight_OVSDB_Architecture
OVSDB MDSAL南向:https://wiki.opendaylight.org/view/OVSDB:MDSAL_Southbound
基于OpenDaylight和OVSDB搭建VxLAN网络:https://www.sdnlab.com/15030.html
OVSDB与ODL Lithium版本集成测试:
https://wiki.opendaylight.org/view/OpenDaylight_OVSDB:Lithium_Integration_Test

### 配置OpenDaylight控制器连接Open vSwitch (OVS) #### 安装并启动OpenDaylight 为了使 OpenDaylight 控制器能够管理 OVS 设备,需先完成 OpenDaylight 的安装与启动工作。通过访问官方网站获取预编译版本,并按照标准流程解压缩文件夹后执行启动命令[^2]。 ```bash tar -xvf distribution-karaf-*.tar.gz cd distribution-karaf-* ./bin/karaf ``` 这会启动 Karaf 容器内的 OpenDaylight 实例,准备接收来自网络设备的消息。 #### 升级Mininet中的Open vSwitch至最新稳定版 考虑到 Mininet 自带的 Open vSwitch 版本可能较为陈旧,建议将其更新到较新版本以确保兼容性和功能性[^3]。具体方法取决于操作系统环境;对于基于 Ubuntu 的系统来说,可以通过包管理工具 apt 或者手动编译方式来实现这一目标。 #### 设置OVS以便于被ODL控制 为了让 OVS 能够接受来自 OpenDaylight 的指令,需要对其进行适当设置: 1. **创建桥接接口** 使用 `ovs-vsctl` 命令行工具新建一个名为 br0 的网桥实例: ```bash sudo ovs-vsctl add-br br0 ``` 2. **启用远程协议通信** 修改 OVS 参数允许其监听外部控制器请求,默认情况下端口为 6653(即 OpenFlow 1.3 标准所指定)。同时指明控制器 IP 地址指向运行着 OpenDaylight 的机器地址。 ```bash sudo ovs-vsctl set-controller tcp:<controller-ip>:6653 sudo ovs-vsctl set-fail-mode secure ``` 上述操作完成后,OVS 将尝试向给定 IP 和端口号发起 TCP 连接握手动作,一旦成功则意味着两者之间建立了有效的联系通道[^1]。 #### 测试连通性 最后一步是在 OpenDaylight Web UI 中验证节点状态以及拓扑结构显示情况。如果一切正常的话,应该可以看到代表 OVS 的图标出现在图形界面上,并且可以进一步探索更多关于该交换机的信息和服务选项。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值