首页
/ Cloud-init与MAAS集成中的OVS网络配置问题分析与解决方案

Cloud-init与MAAS集成中的OVS网络配置问题分析与解决方案

2025-06-25 20:18:34作者:幸俭卉

问题背景

在Ubuntu 24.04系统中使用MAAS部署带有OVS(Open vSwitch)桥接配置的机器时,用户遇到了cloud-init无法正确配置网络的问题。具体表现为部署过程中MAAS无限期等待机器就绪,导致部署失败。该问题在Ubuntu 22.04系统中不存在,但在24.04系统中普遍出现。

问题现象分析

通过对比22.04和24.04系统的部署日志,可以观察到关键差异:

  1. 服务启动顺序不同

    • 在22.04系统中,服务启动顺序为:cloud-init本地阶段→systemd-networkd→OVS相关服务→网络就绪→cloud-init网络阶段
    • 在24.04系统中,服务启动顺序变为:cloud-init本地阶段→systemd-networkd→部分OVS服务→cloud-init网络阶段→网络就绪
  2. 网络状态检测差异

    • 24.04系统中,systemd-networkd-wait-online服务被配置为仅等待物理网卡(enp5s0)的载波状态,而忽略了OVS桥接(br0)的状态
    • 这导致cloud-init网络阶段启动时,实际的桥接网络尚未就绪

根本原因

问题根源在于Netplan的设计变更。在24.04系统中,Netplan默认将桥接接口标记为"optional"(可选),这导致systemd-networkd-wait-online服务不会等待这些接口就绪。具体表现为:

  1. Netplan生成的systemd-networkd-wait-online服务配置中,明确指定了只检测物理网卡的状态参数(-i enp5s0:carrier)
  2. 由于OVS桥接(br0)没有被包含在等待列表中,网络实际上并未完全就绪时cloud-init就开始执行网络配置阶段

解决方案

针对此问题,有两种可行的解决方案:

方案一:修改Netplan配置

在Netplan配置中为OVS桥接明确添加optional: false参数,强制系统等待该接口就绪:

network:
  bridges:
    br0:
      optional: false
      addresses:
      - 10.0.2.122/24
      # 其他配置保持不变

此方案已被MAAS团队采纳,并在MAAS 3.4.9、3.5.5和3.6.1版本中实现。

方案二:调整服务依赖关系

对于无法修改Netplan配置的情况,可以手动调整服务依赖关系:

  1. 确保cloud-init.servicesystemd-networkd-wait-online.service之后启动
  2. 或者修改systemd-networkd-wait-online.service的配置,使其包含对桥接接口的等待

技术建议

对于使用MAAS部署Ubuntu系统的用户,建议:

  1. 升级到包含修复的MAAS版本(3.4.9、3.5.5或3.6.1及以上)
  2. 如果暂时无法升级,可以手动在部署后修改Netplan配置并重新应用
  3. 对于自定义镜像,建议在镜像构建阶段就包含正确的Netplan配置

更深层次的系统理解

这个问题实际上反映了现代Linux系统中网络配置复杂性的增加。随着虚拟化网络技术(如OVS)的普及,传统的网络就绪检测机制需要相应调整。在早期版本中,系统通常只需要等待物理网卡就绪,但在使用高级网络功能(如OVS、桥接、绑定等)时,这种简化假设就不再成立。

Netplan和systemd-networkd的这次变更实际上是为了更好地支持复杂网络场景,但同时也要求管理员更明确地表达他们的网络依赖关系。通过将接口显式标记为"非可选"(optional: false),系统可以更准确地理解哪些网络组件对系统正常运行至关重要。

总结

Cloud-init与MAAS在Ubuntu 24.04中的OVS网络配置问题是一个典型的系统组件交互问题。通过理解Netplan、systemd-networkd和cloud-init之间的协作机制,我们不仅可以解决当前问题,还能更好地设计和管理复杂的网络部署场景。这个案例也提醒我们,在系统升级时需要特别注意组件间依赖关系的变化,特别是在网络配置这种基础而关键的领域。

登录后查看全文
热门项目推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
261
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
858
511
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
258
298
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
332
1.08 K
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
kernelkernel
deepin linux kernel
C
22
5