一、环境准备

1. 硬件要求

  • 控制节点:至少 4 核 CPU,8GB 内存,100GB 磁盘(推荐 SSD)。

  • 计算节点:根据虚拟机需求调整,建议 8 核 CPU,16GB 内存,200GB+ 磁盘。

  • 网络节点(可选):若需独立网络服务,分配 2 核 CPU,4GB 内存。

2. 操作系统

  • 推荐系统:Ubuntu 22.04 LTS 或 CentOS 9 Stream。

  • 所有节点需满足以下条件

    # 关闭 SELinux(CentOS)
    sudo setenforce 0
    sudo sed -i 's/^SELINUX=enforcing/SELINUX=permissive/' /etc/selinux/config # 关闭防火墙(测试环境)
    sudo systemctl stop firewalld && sudo systemctl disable firewalld # CentOS
    sudo ufw disable # Ubuntu # 配置时间同步(NTP/Chrony)
    sudo timedatectl set-ntp true

3. 主机名与网络规划

  • 主机名:确保所有节点的主机名可解析(如 controllercompute1)。

  • 网络规划

    • 管理网络(Management Network):10.0.0.0/24

    • 业务网络(Tunnel/Data Network):10.0.1.0/24

    • 外部网络(External Network):与物理网络桥接(如 192.168.1.0/24)。


二、安装依赖与工具

1. 安装 Python 和 Ansible

# Ubuntu
sudo apt update
sudo apt install -y python3-dev python3-pip git
sudo pip3 install -U pip ansible # CentOS
sudo dnf install -y python3-devel git
sudo pip3 install -U pip ansible

2. 安装 Docker 和依赖

# Ubuntu
sudo apt install -y docker.io
sudo systemctl enable --now docker # CentOS
sudo dnf config-manager --add-repo=https://download.docker.com/linux/centos/docker-ce.repo
sudo dnf install -y docker-ce
sudo systemctl enable --now docker # 配置 Docker 镜像加速(可选)
sudo tee /etc/docker/daemon.json <<EOF
{
"registry-mirrors": ["https://<your-mirror>.mirror.aliyuncs.com"]
}
EOF
sudo systemctl restart docker

3. 安装 Kolla-Ansible

sudo pip3 install git+https://opendev.org/openstack/kolla-ansible@stable/zed
sudo mkdir -p /etc/kolla
sudo cp -r /usr/local/share/kolla-ansible/etc_examples/kolla/* /etc/kolla/
sudo cp /usr/local/share/kolla-ansible/ansible/inventory/* /etc/kolla/

三、配置 Kolla-Ansible

1. 生成全局配置文件

# 生成密码文件
sudo kolla-ansible genpwd # 编辑全局配置(/etc/kolla/globals.yml)
sudo vim /etc/kolla/globals.yml # 关键配置项
kolla_base_distro: "centos" # 或 "ubuntu"
kolla_internal_vip_address: "10.0.0.100" # 控制节点 VIP
network_interface: "eth0" # 管理网络接口
neutron_external_interface: "eth1" # 外部网络接口
enable_cinder: "yes"
enable_cinder_backend: "lvm"
glance_backend: "file"

2. 配置 Inventory 文件

sudo vim /etc/kolla/inventory/multinode  

# 示例配置
[control]
controller [network]
controller [compute]
compute1 [monitoring]
controller [storage]
controller

四、部署 OpenStack

1. 执行预检查

sudo kolla-ansible -i /etc/kolla/inventory/multinode bootstrap-servers
sudo kolla-ansible -i /etc/kolla/inventory/multinode prechecks

2. 开始部署

sudo kolla-ansible -i /etc/kolla/inventory/multinode deploy  

3. 生成管理员凭据

sudo kolla-ansible post-deploy
source /etc/kolla/admin-openrc.sh # 加载环境变量

五、验证与初始化

1. 验证服务状态

# 检查容器运行状态
sudo docker ps # 检查 OpenStack 服务
openstack compute service list
openstack network agent list

2. 创建初始资源

# 创建外部网络
openstack network create --external --provider-physical-network physnet1 --provider-network-type flat public
openstack subnet create --network public --subnet-range 192.168.1.0/24 --gateway 192.168.1.1 --allocation-pool start=192.168.1.100,end=192.168.1.200 public-subnet # 创建测试虚拟机
wget https://cloud-images.ubuntu.com/jammy/current/jammy-server-cloudimg-amd64.img
openstack image create --file jammy-server-cloudimg-amd64.img --disk-format qcow2 --container-format bare ubuntu-jammy
openstack flavor create --ram 2048 --disk 20 --vcpus 2 m1.small
openstack server create --image ubuntu-jammy --flavor m1.small --network public test-vm

六、后续维护与扩展

1. 添加计算节点

# 在新节点安装依赖并加入 Inventory
sudo vim /etc/kolla/inventory/multinode
[compute]
compute1
compute2 # 重新部署
sudo kolla-ansible -i /etc/kolla/inventory/multinode deploy

2. 升级 OpenStack

# 更新 Kolla-Ansible
sudo pip3 install -U kolla-ansible # 执行升级
sudo kolla-ansible -i /etc/kolla/inventory/multinode upgrade

3. 备份与恢复

# 备份数据库
sudo docker exec -it mariadb mysqldump -uroot -p$(grep 'database_password' /etc/kolla/passwords.yml | awk '{print $2}') --all-databases > openstack-backup.sql # 恢复数据库
sudo docker exec -i mariadb mysql -uroot -p$(grep 'database_password' /etc/kolla/passwords.yml | awk '{print $2}') < openstack-backup.sql

七、故障排查

1. 查看容器日志

sudo docker logs <container_name>  

2. 检查网络配置

# 验证 Neutron Agent
openstack network agent list # 检查 OVS 桥接
sudo ovs-vsctl show

总结

  • 核心工具:Kolla-Ansible 提供了容器化部署的标准化流程,适合生产环境。

  • 关键步骤:网络规划、Inventory 配置、全局参数调优。

  • 扩展性:通过添加计算/存储节点横向扩展资源。

  • 注意事项

    • 生产环境需启用 TLS 加密和防火墙规则。

    • 定期备份数据库和配置文件。

OpenStack 全套搭建部署指南(基于 Kolla-Ansible)的更多相关文章

  1. Disconf 学习系列之全网最详细的最新稳定Disconf 搭建部署(基于Ubuntu14.04 / 16.04)(图文详解)

    不多说直接上干货! https://www.cnblogs.com/wuxiaofeng/p/6882596.html (ubuntu16.04) https://www.cnblogs.com/he ...

  2. Spark集群基于Zookeeper的HA搭建部署笔记(转)

    原文链接:Spark集群基于Zookeeper的HA搭建部署笔记 1.环境介绍 (1)操作系统RHEL6.2-64 (2)两个节点:spark1(192.168.232.147),spark2(192 ...

  3. PHP 基于 Jenkins ansible 动态选择版本进行自动化部署与回滚(第二版)

    PHP 基于 Jenkins ansible 动态选择版本进行自动化部署与回滚(第二版) 先看流程图: 大概介绍一下: 版本选择使用jenkins 中的 git parameter 插件实现 回滚方式 ...

  4. zabbix环境搭建部署(一)

     Linux高端架构师课程 Linux实战运维国内NO.1全套视频课程 QQ咨询:397824870  > 监控报警 > zabbix环境搭建部署(一) zabbix环境搭建部署(一) 监 ...

  5. openstack高可用集群21-生产环境高可用openstack集群部署记录

    第一篇 集群概述 keepalived + haproxy +Rabbitmq集群+MariaDB Galera高可用集群   部署openstack时使用单个控制节点是非常危险的,这样就意味着单个节 ...

  6. 理解 OpenStack + Ceph (1):Ceph + OpenStack 集群部署和配置

    本系列文章会深入研究 Ceph 以及 Ceph 和 OpenStack 的集成: (1)安装和部署 (2)Ceph RBD 接口和工具 (3)Ceph 物理和逻辑结构 (4)Ceph 的基础数据结构 ...

  7. Redis 集群搭建详细指南

    先有鸡还是先有蛋? 最近有朋友问了一个问题,说毕业后去大城市还是小城市?去大公司还是小公司?我的回答都是大城市!大公司! 为什么这么说呢,你想一下,无论女孩男孩找朋友都喜欢找个子高胸大的.同样的道理嘛 ...

  8. 首发福利!全球第一开源ERP Odoo系统架构部署指南 电子书分享

    引言 Odoo,以前叫OpenERP,是比利时Odoo S.A.公司开发的一个企业应用软件套件,开源套件包括一个企业应用快速开发平台,以及几千个Odoo及第三方开发的企业应用模块.Odoo适用于各种规 ...

  9. Ubuntu14.04下Ambari安装搭建部署大数据集群(图文分五大步详解)(博主强烈推荐)

    不多说,直接上干货! 写在前面的话 (1) 最近一段时间,因担任我团队实验室的大数据环境集群真实物理机器工作,至此,本人秉持负责.认真和细心的态度,先分别在虚拟机上模拟搭建ambari(基于CentO ...

  10. 《Openstack的搭建》RHEL6.5

    Openstack就是搭建一个较为完整的虚拟化平台,把一个完整的物理机划分成若干个虚拟机来跑,从而实现资源的充分利用. Openstack对硬件的要求很高,要是你的物理机内存是4G的话,虚拟机的内存给 ...

随机推荐

  1. server_patrol.sh服务器巡查脚本

    server_patrol.sh #!/bin/bash #!/usr/bin/expect -f#! auther by wangxp #定义一个变量 LANG="zh_CN.UTF-8& ...

  2. Atcoder ABC387F Count Arrays 题解 [ 绿 ] [ 基环树 ] [ 树形 dp ] [ 前缀和优化 ]

    Count Arrays:一眼秒的计数题. 思路 显然,把小于等于的条件化为大的向小的连单向边,每个数的入度都是 \(1\),就会形成一个基环树森林. 那么考虑这个环上能填什么数.因为所有数都小于等于 ...

  3. 傻妞教程——对接QQ频道机器人

    安装插件 前往傻妞插件市场安装QQ频道机器人插件,基于Node开发. 申请机器人 使用前请先确保已在机器人平台创建机器人 (opens new window),具体创建教程在超链接里面有,根据教程图以 ...

  4. IDEA - 文件上方的文档注释如何自定义

    1.在设置中打开文件和代码模板,根据描述中的参考信息进行自定义配置 File > Settings > Editor > File and Code Templates 2.配置完成 ...

  5. ARC101E题解

    前言 此片题解大致按照笔者做题思路进行讲解. 简要题意 有一棵树,树上有偶数个节点.你需要给这些点两两配对,一组已经配对的点会将两点之间的树边进行一次覆盖.一组合法方案需要满足树上所有边都被覆盖至少一 ...

  6. linux系统批量查找网站源码并替换字符,查找替换指定内容

    问题描述:维护中需要批量修改代码中某个字符,如果单个打开页面进行修改则效率过低,linux系统下借助grep命令快速查找替换 命令示例1: grep -rl '查找的内容' . | xargs sed ...

  7. Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南

    引言:AI技术新纪元的破局者 2025年3月6日凌晨,武汉Monica团队正式发布全球首款通用AI代理系统Manus,该工具在GitHub开源社区引发热议,单日Star数突破5万.与传统对话式AI不同 ...

  8. 【Logisim】带有初始化功能的寄存器

    属于是拾人牙慧 子电路外观 子电路逻辑 描述: Q端 Counter + MUX : 实现初始化.初始时MUX选择init,待时钟第一个上升沿后,Counter([Data Bit]:1bit,[Ac ...

  9. SVG path 标签根据两点和角度绘制弧线

    同步发布:https://blog.jijian.link/2020-04-14/svg-arc/ 由于功能受限,此处不能放 iframe 嵌入链接,如需看到实时效果,请移步 https://blog ...

  10. .NET周刊【3月第1期 2025-03-02】

    国内文章 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章 https://www.cnblogs.com/shanyou/p/18737657 2025年2月25日,.NET ...