Neutron升级规划

2023-12-19 10:18
文章标签 规划 升级 neutron

本文主要是介绍Neutron升级规划,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文档的大部分内容讨论通过Neutron agents实现的升级相关考虑。期望于每个Neutron插件提供其自身的特定于后端选择的升级讨论文档。例如,OVN不使用Neutron agent,但是确实有本地控制器运行在每个计算节点。OVS支持滚动升级,但是,关于如何工作的文档应包含在networking-ovn(OVN Neutron插件)中。

升级规划

Neutron支持两种通用的升级场景:

  • 关闭所有的服务,升级代码,之后重启所有服务.
  • 基于运营者的服务窗口,逐渐的升级服务.

后者时升级OpenStack云的首选,因为其允许更细的控制和更少的服务关闭时间。此场景通过称为“滚动升级”。

滚动升级 Rolling upgrade

滚动升级意味着在某段时间内,不同代码版本的服务在同时允许,并在云中交互。这对软件施加了多个限制.

  1. 老版本服务应当能与新服务通信.
  2. 老版本服务不应要求数据库具有老的schema (否则要求新schema的新版本服务将不能工作).

更多关于OpenStack滚动升级的信息可参考:https://governance.openstack.org/tc/reference/tags/assert_supports-rolling-upgrade.html.

Neutron通过以下方式实现这些要求:

  1. 如果Neutron后端使用Neutron agents,Neutron服务端具有向后兼容的代码处理老版本消息负荷。
  2. 隔离访问数据库的当个服务 (neutron-server).

简化起见,总是假设服务升级的顺序如下所示:

  1. 首先,所有的 neutron-servers 进行升级.
  2. 之后,如果可行,升级Neutron agents.

此方法允许我们在agent一侧避免向后兼容的代码,并和其它支持滚动升级的OpenStack project保持一致(特别的, Nova)。

服务器升级

Neutron-server是非常靠前的应升级到新版本代码的组件。它也是唯一的依赖于新的数据库schema的组件。其它组件通过AMQP与云通信,并不依赖与特定的数据库状态。

数据库升级是通过alembic迁移链实现的。

数据库升级分为两个部分:

  1. neutron-db-manage upgrade --expand
  2. neutron-db-manage upgrade --contract

每个部分代表一个独立的alembic分支.

前一个步骤可在老的neutron-server代码运行时执行。后一个步骤要求”所有“的neutron-server实例处于关闭状态。一旦完成,neutron-servers可被重新启动。

:
neutron-server实例的完全关闭可跳过,此依赖于是否存在挂起的未应用到数据库的contract脚本:

$ neutron-db-manage has_offline_migrations

此命令将返回是否存在挂起的contract脚本信息。.

Agents 升级

:
如果云不使用AMQP agents为实例提供网络服务,本节不应用。此情况下,其它后端应用特定的升级指令。

一旦带有新的数据库schema和新代码的neutron-server重新启动,到了升级Neutron agents的时刻.

注意与此同时,neutron-server应能够处理云中老版本agents发送的AMQP消息。

推荐的agent升级(每个节点)顺序如下:

  1. 首先,L2 agents (openvswitch, linuxbridge, sr-iov).
  2. 其次, 所有其它 agents (L3, DHCP, Metadata, …).

agent升级顺序的原因是L2 agent通常负责连线port到其它使用的agent,所以,最好先允许其完成工作,之后继续其它的agent,这些agent将使用已经根据需要配置好的port。

每个network/compute节点可使用其自身的升级安排,独立于其它的节点。

AMQP 考虑

既然总是假设neutron-server组件在其它agent之前升级,仅前者需要处理新旧两个RPC版本。

意味着不需要代码处理属于agent的UnsupportedVersion oslo.messaging异常。

通知Notifications

对于neutron-server发给监听agent的通知,需要特殊的考虑以支持滚动升级。在此情况下,一个新的控制器发送新的负荷到老的agent上。

在我们有了适当的RPC版本固定功能,于升级过程中强制旧的负载格式(类似在其它project中的实现,如Nova)之前,我们让agents抵抗作为服务器通知中一部分的未知参数。这是通过不断地捕获那些未知的带有关键字的参数,并在agent端忽略它们;以及不在服务器端强制新的RPC入口点版本。

此方式并不理想,因为它使得RPC API不严格。这就是为什么将来应为通知考虑其它的方式。

接口签名

RPC接口由其名称、版本及其接受的参数(named)定义。没有严格的保证参数用于期待的类型或意义,因为它们被串行化了。

消息内容版本化

为了滚动升级提供更好的兼容性保证,RPC接口也应定义特定的可接受的参数格式。在OpenStack世界中,它通常使用slo.versionedobjects实现,并依赖于库为通过AMQP传递的参数定义串行化格式。

注意,Neutron还没有为其RPC接口采用oslo.versionedobjects库(QoS特性已采用)。

网络后端backends

后端软件升级不应导致任何数据平面的中断。意味着,例如,Open vSwitch L2 agent不应重置流或者重连ports;Neutron L3 agent不应删除老版本agent留下的命名空间;Neutron DHCP agent不应请求立即的DHCP租约更新;等待。

同样的考虑应用于不依赖agents的建立。意味着,比如,OpenDaylight 或 OVN 控制器不应在升级过程中断开数据平面的连通性。

升级测试

Grenade 是OpenStack设计来验证升级场景的project。

当前,仅离线(非滚动)升级场景可在Neutron gate验证。升级场景为以下步骤:

  1. 老的云使用最新的稳定发布代码建立
  2. 停止所有的服务
  3. 代码更新到要检视的补丁版本
  4. 如果需要,应用新的数据库迁移脚本
  5. 启动所有服务
  6. 使用暴力测试子集验证新的云

此场景验证在一个循环中没有配置选项名称被修改。更通用的,它验证新的云能够使用老云的配置文件运行。它也验证数据库迁移脚本是否可执行。

此场景并不验证AMQP版本兼容性。

其它projects(如Nova)具有称为“partial” Grenade工作,其中一些服务可运行老版本代码。这样的工作在Neutron gate中也需要来验证project的滚动升级。目前为止,依赖于代码检视者在补丁中发现兼容性问题。

另一个测试中的洞属于拆分迁移脚本分支。假设老版本云在从新版云扩展迁移脚本之后,可成功的运行并应用与其数据库,但是没有在gate中验证。

审阅指南

有几个升级相关的点应该由审阅者跟踪。

先说重点,对审阅者的一般建议:确保新代码不违反 global OpenStack deprecation policy 设置的要求.

现在具体来说:

  • 配置选项:

    • 不应不等待废弃周期而从代码树中删除选项(目前是一个开发周期长度),并且如果使用废弃的选项应提示废弃信息。
    • 选项值不应在版本之间改变意义.
  • 数据平面:

    • agent重启不应打断数据平面(无Open vSwitch 端口重置;无网络命名空间删除;无设备名称改变).
  • RPC 版本化:

    • 在所有代理都有机会升级之前,不应删除任何RPC主版本号(意味着,在处理老版本客户端的兼容代码被从代码树移除之前,至少需要一个发布周期)。
    • 不应在AMQP接口的agent侧添加兼容代码.
    • 服务端代码应能处理所有之前版本的agents,直到接口的主版本号删除。
    • RPC接口的参数不应修改意义,或者名称.
    • 添加到RPC接口的新参数不应是强制的。这意味着该服务器应能处理旧的请求,而不需要新指定的参数。另外,如果参数未传递,应保留在添加参数之前的老的行为。
    • 对于服务器初始的通知,最小客户端版本至少一个周期的后才能更改。
  • 数据库迁移:

    • 迁移代码应按要求分成两个分支(contract、expand)。neutron-server运行时不能安全执行的代码应添加到expand分支。
    • 如果可能,contract迁移应尽量最小化或避免,以减少在数据库升级期间,API端点必须关闭的时间。

这篇关于Neutron升级规划的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/511824

相关文章

你的华为手机升级了吗? 鸿蒙NEXT多连推5.0.123版本变化颇多

《你的华为手机升级了吗?鸿蒙NEXT多连推5.0.123版本变化颇多》现在的手机系统更新可不仅仅是修修补补那么简单了,华为手机的鸿蒙系统最近可是动作频频,给用户们带来了不少惊喜... 为了让用户的使用体验变得很好,华为手机不仅发布了一系列给力的新机,还在操作系统方面进行了疯狂的发力。尤其是近期,不仅鸿蒙O

动态规划---打家劫舍

题目: 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。 给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。 思路: 动态规划五部曲: 1.确定dp数组及含义 dp数组是一维数组,dp[i]代表

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同

poj 2976 分数规划二分贪心(部分对总体的贡献度) poj 3111

poj 2976: 题意: 在n场考试中,每场考试共有b题,答对的题目有a题。 允许去掉k场考试,求能达到的最高正确率是多少。 解析: 假设已知准确率为x,则每场考试对于准确率的贡献值为: a - b * x,将贡献值大的排序排在前面舍弃掉后k个。 然后二分x就行了。 代码: #include <iostream>#include <cstdio>#incl

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

数学建模笔记—— 非线性规划

数学建模笔记—— 非线性规划 非线性规划1. 模型原理1.1 非线性规划的标准型1.2 非线性规划求解的Matlab函数 2. 典型例题3. matlab代码求解3.1 例1 一个简单示例3.2 例2 选址问题1. 第一问 线性规划2. 第二问 非线性规划 非线性规划 非线性规划是一种求解目标函数或约束条件中有一个或几个非线性函数的最优化问题的方法。运筹学的一个重要分支。2

macOS升级后SVN升级

问题 svn: error: The subversion command line tools are no longer provided by Xcode. 解决 sudo chown -R $(whoami) /usr/local/Cellar brew install svn

轨迹规划-B样条

B样条究竟是干啥的?白话就是给出一堆点,用样条的方式,给这些点连接起来,并保证丝滑的。 同时B样条分为准均匀和非均匀,以下为准均匀为例。 参考链接1:https://zhuanlan.zhihu.com/p/50626506https://zhuanlan.zhihu.com/p/50626506 参考链接2: https://zhuanlan.zhihu.com/p/536470972h

PMBOK® 第六版 规划进度管理

目录 读后感—PMBOK第六版 目录 规划进度管理主要关注为整个项目期间的进度管理提供指南和方向。以下是两个案例,展示了进度管理中的复杂性和潜在的冲突: 案例一:近期,一个长期合作的客户因政策要求,急需我们为多家医院升级一个小功能。在这个过程中出现了三个主要问题: 在双方确认接口协议后,客户私自修改接口并未通知我们,直到催进度时才发现这个问题关于UI设计的部分,后台开发人员未将其传递给

LeetCode:64. 最大正方形 动态规划 时间复杂度O(nm)

64. 最大正方形 题目链接 题目描述 给定一个由 0 和 1 组成的二维矩阵,找出只包含 1 的最大正方形,并返回其面积。 示例1: 输入: 1 0 1 0 01 0 1 1 11 1 1 1 11 0 0 1 0输出: 4 示例2: 输入: 0 1 1 0 01 1 1 1 11 1 1 1 11 1 1 1 1输出: 9 解题思路 这道题的思路是使用动态规划