解析OVN架构及其在OpenStack中的集成

引言

随着云计算技术的发展,虚拟化网络成为云平台不可或缺的一部分。为了更好地管理和控制虚拟网络,Open Virtual Network (OVN) 应运而生。作为Open vSwitch (OVS) 的扩展,OVN 提供了对虚拟网络抽象的支持,使得大规模部署和管理变得更加容易。本文将详细介绍 OVN 架构、它与 OpenStack 的集成方式、基于 OVN 的虚拟网络实现以及 OVN 在其中发挥的作用。

OVN架构详解

1. 架构概述

OVN 是一个支持虚拟网络抽象的系统,旨在为云环境提供分布式虚拟交换机和路由器的功能。它的设计目标是能够大规模运行,并且可以与多种云管理系统(CMS)集成,如OpenStack。OVN 架构由以下几个关键部分组成:
在这里插入图片描述

  • 云管系统(Cloud Management System, CMS):这是用户和管理员与 OVN 交互的主要界面,通常指代的是像 OpenStack 这样的云平台。
  • OVN/CMS 插件:用于将 CMS 中定义的逻辑网络配置转换成 OVN 可以理解的形式,并写入北向数据库中。
  • OVN 北向数据库 (Northbound Database):存储从 CMS 插件传递过来的逻辑网络配置信息。
  • ovn-northd:这是一个集中式的控制器,负责将北向数据库中的逻辑网络配置转换为更底层的数据路径流规则,并将其写入南向数据库。
  • OVN 南向数据库 (Southbound Database):保存 ovn-northd 转换后的数据路径流规则,以及物理网络信息。
  • ovn-controller:每个 虚拟层(KVM、Xen、hyperv)或网关上的代理程序,负责连接到南向数据库获取最新配置,并应用到本地的 OVS 上。
  • ovs-vswitchd 和 ovsdb-server:这是 OVS 的核心组件,负责实际的数据包转发工作

2. 数据流动

在 OVN 中,配置数据是从上至下流动的,即从 CMS 开始,经过 OVN/CMS 插件、北向数据库、ovn-northd 到达南向数据库,最后由各个节点上的 ovn-controller 实施。相反地,状态信息则是自下而上传递,例如当某个 VM 启动后,其对应的逻辑端口会被标记为“up”,这一变化会通过南向数据库反馈给 ovn-northd 并最终反映到 CMS。

OVN与OpenStack集成

1. 集成背景

OpenStack Neutron 是 OpenStack 项目中负责网络服务的模块,最初依赖于多种插件来实现不同的网络功能。然而,随着需求的增长和技术的进步,Neutron 的架构逐渐暴露出一些性能瓶颈。为此,OVS 社区推出了 OVN 项目,旨在简化 Neutron 的架构并提高整体性能。通过使用 OVN 作为 Neutron 的后端,不仅可以减少消息队列机制带来的延迟,还能让 Neutron 更专注于 API 层面的工作。

2. 具体步骤

要将 OVN 集成到 OpenStack 环境中,首先需要确保所有计算节点都安装了 OVS 和 OVN 相关软件包。接着,在 OpenStack 控制节点上配置 neutron.conf 文件,指定使用 OVN ML2 插件,并设置相应的 VNI 范围等参数。此外,还需要调整 neutron-server 和其他相关服务的启动脚本,使其能够正确加载 OVN 插件。

对于已经存在的 OpenStack 环境来说,可以通过逐步迁移的方式引入 OVN 支持。例如,可以在不影响现有业务的前提下先在一个子网内测试 OVN 的表现,待验证无误后再推广至整个集群。

基于OVN的虚拟网络实现

1. 虚拟二层网络

OVN 提供了原生的 L2 网络支持,允许创建多个隔离的虚拟 LAN (VLAN),并通过 Geneve 等隧道协议实现跨主机通信。每个 VLAN 可以被视为一个独立的广播域,确保不同租户之间的流量不会相互干扰。同时,OVN 还支持 DHCP 和 DNS 服务,帮助简化 IP 地址分配过程。

2. 分布式三层路由

除了基本的二层功能外,OVN 还实现了分布式虚拟路由器,能够在多个计算节点之间分发路由表项,从而提高了路由决策的速度和效率。更重要的是,这种分布式设计避免了单点故障的风险,增强了系统的可靠性和容错能力。

3. 安全组和 ACL

为了保障网络安全,OVN 引入了安全组的概念,允许管理员根据 MAC 地址、IP 地址或端口号设置访问控制列表 (ACL)。这些规则可以直接作用于 OVS 内部接口,无需借助额外的防火墙设备,既减少了复杂度又提升了处理速度。

OVN的作用

1. 提升性能

相比于传统的 Neutron 架构,OVN 减少了中间环节的数量,直接利用 OVSDB 协议进行读写操作,显著降低了 RPC 消息传输的开销。这不仅加快了配置同步的速度,也减轻了控制平面的压力。

2. 增强灵活性

由于 OVN 本身是一个高度模块化的系统,因此它可以轻松适应各种不同的应用场景。无论是公有云还是私有云,无论是容器还是虚拟机,只要能运行 OVS,就可以部署 OVN 来构建灵活多变的虚拟网络。

3. 简化运维

得益于其清晰的角色划分和自动化程度较高的特性,OVN 大大简化了日常维护工作。比如,当 VM 发生迁移时,OVN 可以自动更新相关的流表规则,保证新位置下的正常通信;而对于大规模集群而言,管理员也可以方便地监控和管理整个网络的状态。

综上所述,OVN 不仅解决了传统网络架构中存在的诸多问题,还为企业级用户提供了更加便捷高效的解决方案。未来,随着 SDN 技术的不断发展和完善,相信 OVN 将会在更多领域展现出其独特的优势。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/907.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第三十六章 Spring之假如让你来写MVC——拦截器篇

Spring源码阅读目录 第一部分——IOC篇 第一章 Spring之最熟悉的陌生人——IOC 第二章 Spring之假如让你来写IOC容器——加载资源篇 第三章 Spring之假如让你来写IOC容器——解析配置文件篇 第四章 Spring之假如让你来写IOC容器——XML配置文件篇 第五章 Spring之假如让你来写…

CSS 盒模型

盒模型 CSS盒模型是网页布局的核心概念之一,它描述了网页元素的物理结构和元素内容与周围元素之间的关系。根据W3C规范,每个HTML元素都被视为一个矩形盒子,这个盒子由以下四个部分组成: 内容区(Content area&#xff…

JVM:ZGC详解(染色指针,内存管理,算法流程,分代ZGC)

1,ZGC(JDK21之前) ZGC 的核心是一个并发垃圾收集器,所有繁重的工作都在Java 线程继续执行的同时完成。这极大地降低了垃圾收集对应用程序响应时间的影响。 ZGC为了支持太字节(TB)级内存,设计了基…

OpenCV基于均值漂移算法(pyrMeanShiftFiltering)的水彩画特效

1、均值漂移算法原理 pyrMeanShiftFiltering算法结合了均值迁移(Mean Shift)算法和图像金字塔(Image Pyramid)的概念,用于图像分割和平滑处理。以下是该算法的详细原理: 1.1 、均值迁移(Mean …

【数学】概率论与数理统计(五)

文章目录 [toc] 二维随机向量及其分布随机向量离散型随机向量的概率分布律性质示例问题解答 连续型随机向量的概率密度函数随机向量的分布函数性质连续型随机向量均匀分布 边缘分布边缘概率分布律边缘概率密度函数二维正态分布示例问题解答 边缘分布函数 二维随机向量及其分布 …

四 BH1750 光感驱动调试2

之前调通了用户态接口,android 使用还是不方便,要包装jni使用。 这里集成了内核 iio 驱动 ,提供 sys-fs 文件接口 可供固件以及 ANDROID 应用层使用 一 驱动集成 : 1.1 dts 修改 修改文件 : kernel/arch/arm64/boot/dts/rockchip/rp-rk3568.dts 在 i2c5 增加设备,如…

Redis持久化双雄

Redis持久化 Redis 的持久化是指将内存中的数据保存到硬盘,以防止服务器宕机导致数据丢失的机制。 redis 提供了两种持久化的方式,分别是RDB(Redis DataBase)和AOF(Append Only File)。 RDB,简…

工业视觉2-相机选型

工业视觉2-相机选型 一、按芯片类型二、按传感器结构特征三、按扫描方式四、按分辨率大小五、按输出信号六、按输出色彩接口类型 这张图片对工业相机的分类方式进行了总结,具体如下: 一、按芯片类型 CCD相机:采用电荷耦合器件(CC…

数字证书管理服务

阿里云数字证书管理服务(Aliyun Certificate Management Service, ACM)是一种云端服务,专门用于帮助企业管理和颁发数字证书。数字证书是网络安全中的重要组成部分,它可以确保通信的安全性、身份认证以及数据的完整性。通过阿里云…

《跟我学Spring Boot开发》系列文章索引❤(2025.01.09更新)

章节文章名备注第1节Spring Boot(1)基于Eclipse搭建Spring Boot开发环境环境搭建第2节Spring Boot(2)解决Maven下载依赖缓慢的问题给火车头提提速第3节Spring Boot(3)教你手工搭建Spring Boot项目纯手工玩法…

Zookeeper概览

个人博客地址:Zookeeper概览 | 一张假钞的真实世界 设计目标 简单的:方便使用以实现复杂的业务应用。复制式的:跟Zookeeper协调的分布式进程一样,它也是在一组服务器上复制的。集群的每个节点间互相知道。它们维护一个状态数据在…

播放音频文件同步音频文本

播放音频同步音频文本 对应单个文本高亮显示 使用audio音频文件对应音频文本资源 音频文本内容(Json) [{"end": 4875,"index": 0,"speaker": 0,"start": 30,"text": "70号二啊,","tex…

React中ElementFiber对象、WorkInProgress双缓存、ReconcileRenderCommit、第一次挂载过程详解

基础概念 Element对象与Fiber对象 Element对象与Fiber对象 Element 对象 定义 React 的 Element 对象是一个描述用户界面(UI)的普通 JavaScript 对象,通常由 React.createElement 或 JSX 语法生成。 作用 它是 React 应用中的一种描述 …

【airtest】自动化入门教程Poco元素定位

1. 前言 本文将详细讲解Poco控件定位的各种方式,利用这些方法可以帮助我们编写出目标控件的定位脚本。我们在IDE录制的poco脚本,常见的都是类似 poco(“star_single”).click()这样的脚本,其中 poco(“star_single”) 这块就属于Poco控件定位…

2025年01月13日Github流行趋势

1. 项目名称:Jobs_Applier_AI_Agent 项目地址url:https://github.com/feder-cr/Jobs_Applier_AI_Agent项目语言:Python历史star数:25929今日star数:401项目维护者:surapuramakhil, feder-cr, cjbbb, sarob…

[免费]SpringBoot+Vue新能源汽车充电桩管理系统【论文+源码+SQL脚本】

大家好,我是java1234_小锋老师,看到一个不错的SpringBootVue新能源汽车充电桩管理系统,分享下哈。 项目视频演示 【免费】SpringBootVue新能源汽车充电桩管理系统 Java毕业设计_哔哩哔哩_bilibili 项目介绍 随着信息化时代的到来&#xff0…

【C++】字符串中的 insert 方法深层分析

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 💯前言💯一、基础知识:insert 方法概述功能描述函数原原型基本规则 💯二、例子解析例子 1:插入一个 std::string分析 例子 2:插入一个…

G-Star Landscape 2.0 重磅发布,助力开源生态再升级

近日,备受行业瞩目的 G-Star Landscape 迎来了其 2.0 版本的发布,这一成果标志着 GitCode 在开源生态建设方面又取得了重要进展。 G-Star Landscape仓库链接: https://gitcode.com/GitCode-official-team/G-Star-landscape 2024 GitCode 开…

Sui Move:基本概览一

Module (模块) Move 代码被组织成模块, 可以把一个模块看成是区块链上的一个智能合约 可以通过调用这些模块中的函数来与模块进行交互,可以通过事务或其他 Move 代码来实现, 事务将被发送到并由Sui区块链进行处理,一旦执行完成,结果的更改将…

不同方式获取音频时长 - python 实现

DataBall 助力快速掌握数据集的信息和使用方式,会员享有 百种数据集,持续增加中。 需要更多数据资源和技术解决方案,知识星球: “DataBall - X 数据球(free)” -------------------------------------------------------------…