前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >OVSDB介绍及在OpenDaylight中的调用

OVSDB介绍及在OpenDaylight中的调用

作者头像
SDNLAB
发布2018-03-29 14:52:12
4.2K1
发布2018-03-29 14:52:12
举报
文章被收录于专栏:SDNLABSDNLAB

前言

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

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2017-08-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 SDNLAB 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 一、OVSDB介绍
    • 1.1 OVSDB管理协议
    • 二、ODL中的OVSDB插件
      • 2.1 OVSDB的不兼容性
        • 2.2 OVSDB南向插件的使用
        • 参考资料
        相关产品与服务
        数据库
        云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档