专栏首页SDNLABOVSDB介绍及在OpenDaylight中的调用

OVSDB介绍及在OpenDaylight中的调用

前言

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

feature:install odl-ovsdb-southbound-impl-uilog: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

ovs-vsctl set-manager tcp:192.168.7.103:6640      //192.168.7.103是控制器的IPcurl -u admin:admin 
http://localhost:8181/restconf/operational/network-topology:network-topology/

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

Shell

ovs-vsctl del-manager  删除连接
ovs-vsctl add-br br01    增加br01 桥

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

Shell

ovs-vsctl set-manager ptcp:6640ovs-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网络:http://www.sdnlab.com/15030.html OVSDB与ODL Lithium版本集成测试: https://wiki.opendaylight.org/view/OpenDaylight_OVSDB:Lithium_Integration_Test

本文分享自微信公众号 - SDNLAB(SDNLAB),作者:超帅的

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2017-08-01

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • OPNFV第五版本Euphrates发布,集成容器化功能

    OPNFV项目是通过集成,部署和测试促进各种开源生态系统网络功能虚拟化(NFV)组件的开发和演进的开源项目,今天宣布推出项目第五个平台版本的OPNFV幼发拉底河...

    SDNLAB
  • Software-Defined Perimeter依旧保持不败战绩

    4月份我们曾报道过云安全联盟推出的接入控制协议 software-defined perimeter (SDP) ,当时云安全联盟宣称只要能够入侵CIA前任特工...

    SDNLAB
  • [新手指南]OPNFV,SDN for OpenStack

    读过之前OpenStack基金会的NFV白皮书的粉丝,想必对OPNFV也不会陌生,本篇文章为大家介绍OPNFV的最新版本-Brahmaptura,帮您快速了解这...

    SDNLAB
  • 测试思想-系统测试 软件版本升级测试(摘录)

    什么是升级测试?比如说你们公司开发的产品现已经发布的是V1.0,由于被发现存在缺陷,这时就需开发Patch或Hot Fix,并进行升级测试,然后发布V1.1。

    授客
  • SQL模糊查询的四种匹配模式

    表示任意0个或多个字符,可匹配任意类型和长度的字符。有些情况下是中文,需用两个百分号(%%)表示:

    Leophen
  • 领云物联徐国:从需求出发,AIoT才能切实为工业安全生产保驾护航丨镁客请讲

    自2017年以来,随着消费互联网红利的消散与我国工业互联网利好政策的到来,工业互联网领域持续升温,后在机器人、大数据、人工智能等技术发展的拉升下,2018年下半...

    镁客网
  • [剑指offer] 连续子数组的最大和

    HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学。今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候...

    尾尾部落
  • 【OCP最新题库解析(052)--题22】Which three of these must be accessible

    小麦苗DBA宝典
  • WWDC 2016:苹果watchOS 3正式亮相

    镁客网
  • 使用Mockito修改Bean的依赖

    在使用单元测试时经常会遇到某些dependency依赖了外部资源,或者想主动绕过真正的方法执行mock返回结果而快速得到单元测试最终的期望结果,可能有以下两种场...

    用户3579639

扫码关注云+社区

领取腾讯云代金券