OpenStack 部署实践与原理解析 - Ubuntu 22.04 部署 (DevStack)
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
文章目录
- 前言
- OpenStack 原理详解
- 1. OpenStack 的架构
- 2. OpenStack 的工作原理
- 3. OpenStack 的 API
- 4. 扩展性和模块化
- OpenStack 安装方式比较
- 1. DevStack
- 2. Kolla
- 3. OpenStack-Ansible
- 4. Manual Installation
- 具体实践:使用 DevStack 部署 OpenStack
- 1. 环境准备
- 2. 克隆 DevStack 仓库
- 3. 创建配置文件
- 4. 启动安装
- 注意
- 5. 访问 OpenStack
- 5. 退出 OpenStack
- 生产与测试环境建议
- 总结
- 其他
前言
OpenStack 是一个强大的开源云计算平台,广泛应用于构建和管理公共与私有云。本文将详细探讨 OpenStack 的原理、不同的安装方式及其适用场景,以帮助读者理解如何高效部署 OpenStack。
OpenStack 原理详解
1. OpenStack 的架构
OpenStack 的架构由多个相互协作的服务组成,主要包括以下核心组件:
Nova(计算):管理虚拟机生命周期,包括启动、停止、重启和迁移。
Neutron(网络):提供网络服务,支持虚拟网络和 IP 地址管理。
Cinder(块存储):提供持久性块存储服务,用户可创建和管理存储卷。
Swift(对象存储):提供分布式对象存储服务,适合存储大量非结构化数据。
Keystone(身份认证):负责用户身份认证和服务目录管理,确保组件间的安全访问。
Glance(镜像服务):管理虚拟机镜像,包括镜像的上传和存储。
Horizon(仪表板):提供图形用户界面,方便用户管理 OpenStack 资源。
2. OpenStack 的工作原理
用户请求:用户通过 API 或 Horizon 界面发送请求,管理资源。
服务协调:组件通过消息队列(如 RabbitMQ)进行通信,处理请求流转。
资源调度:Nova 调度器根据策略选择适合的计算节点部署虚拟机。
虚拟化:结合 KVM、Xen、VMware 等虚拟化技术,创建和管理虚拟机。
数据存储:通过 Cinder 管理块存储,通过 Swift 管理对象存储。
3. OpenStack 的 API
OpenStack 提供 RESTful API,用户和管理员可以通过 API 进行各种操作。这种设计使得 OpenStack 的扩展性和灵活性得到了极大的提升。
4. 扩展性和模块化
OpenStack 的模块化设计允许用户根据需求选择不同组件进行部署,实现灵活的云环境管理。
OpenStack 安装方式比较
根据不同的使用场景和需求,OpenStack 的安装方式可以分为以下几种:
1. DevStack
适用场景:学习、开发和测试环境。
特点:快速、简单,适合用于本地环境的部署,便于试验新功能。
安装方法:只需克隆 DevStack 仓库并运行 ./stack.sh。
2. Kolla
适用场景:生产环境和大规模部署。
特点:使用 Docker 容器化的方式,便于管理和扩展。
安装方法:通过 Ansible 和 Docker 来部署和管理 OpenStack 服务。
3. OpenStack-Ansible
适用场景:中大型生产环境。
特点:基于 Ansible 的部署方式,提供高度可定制的环境,适合复杂的网络和存储配置。
安装方法:通过 Ansible Playbook 来实现部署。
4. Manual Installation
适用场景:有特定需求的自定义部署。
特点:灵活性高,可以根据具体环境配置各个组件。
安装方法:手动安装各个组件,配置相应的服务。
具体实践:使用 DevStack 部署 OpenStack
1. 环境准备
在 22.04.4 LTS live-server 上进行 DevStack 部署:
PS:其他 Ubuntu 版本操作都差不多。
确保系统更新:
sudo apt update && sudo apt upgrade -y
安装必要的依赖:
sudo apt install git -y
创建stack用户:
sudo useradd -s /bin/bash -d /opt/stack -m stack
sudo chmod +x /opt/stack
# 配置免密
echo "stack ALL=(ALL) NOPASSWD: ALL" | sudo tee /etc/sudoers.d/stack
# 切换用户
sudo -u stack -i
2. 克隆 DevStack 仓库
git clone https://git.openstack.org/openstack-dev/devstack.git
cd devstack
3. 创建配置文件
创建一个 local.conf 文件,定义管理员用户名和密码等配置:
[[local|localrc]]
ADMIN_PASSWORD=secret
DATABASE_PASSWORD=$ADMIN_PASSWORD
RABBIT_PASSWORD=$ADMIN_PASSWORD
SERVICE_PASSWORD=$ADMIN_PASSWORD
4. 启动安装
运行安装脚本:
./stack.sh
注意
安装过程中可能会因为某些包、库,国内网不能访问出现问题,执行./ stack.sh 过程中报错会有说明。
解决方法:
1、多执行几次,说不定就下下来了
2、若是 pip 和 apt ,参考清华源官方换源
3、etcd、novnc、cirros 等下载问题,单独下载再放到报错提示目录即可
例如:
提示 etcd-v3.4.27-linux-amd64.tar.gz 有 timeout/not found之类的报错,就网上找它下载地址,按提示
wget https://storage.googleapis.com/etcd/v3.4.27/etcd-v3.4.27-linux-amd64.tar.gz 到 /opt/stack/devstack/files 路径下,重新执行 ./stack.sh 就好
提示 git clone https://github.com/novnc/novnc.git timeout ,就使用代理或能访问 github 的网络下了放到 /opt/stack 路径下,重新执行 ./stack.sh 就好
5. 访问 OpenStack
安装完成后,可以通过访问 http://<你的IP>/dashboard 进入 Horizon 管理界面,使用上方配置的管理员账户登录。
5. 退出 OpenStack
./unstack.sh
# 清除环境(如要)
./clean.sh
PS:无论 ./unstack.sh 再 ./stack.sh 会把实例、镜像等都清了,还原到初始状态。
生产与测试环境建议
生产环境:建议使用 Kolla 或 OpenStack-Ansible,能够提供更好的稳定性和可扩展性。
测试环境:DevStack 是一个很好的选择,快速简单,适合快速迭代和学习。
单机部署:可以使用 DevStack,便于在个人机器上进行实验。
多机部署:Kolla 或 OpenStack-Ansible 更加适合,能够有效管理复杂的多节点环境。
总结
OpenStack 是一个灵活且强大的云计算平台,理解其原理和架构对于成功部署至关重要。根据不同的需求选择合适的安装方式,可以更有效地管理云资源。希望本文能为你的 OpenStack 部署实践提供有价值的参考。
其他
安装或操作过程中遇到的一些问题:
嵌套虚拟化与 OpenStack:我为什么能在虚拟机中再创建虚拟机?
相关文章:
OpenStack 部署实践与原理解析 - Ubuntu 22.04 部署 (DevStack)
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言OpenStack 原理详解1. OpenStack 的架构2. OpenStack 的工作原理3. OpenStack 的 API4. 扩展性和模块化 OpenStack 安装方式比较1. DevStack2. Kolla3. OpenSta…...

【软件工程】可行性研究
一、目的 二、任务 三、步骤 四、结果:可行性研究报告 例题 选择题...

乌克兰因安全风险首次禁用Telegram
据BleepingComputer消息,乌克兰国家网络安全协调中心 (NCCC) 以国家安全为由,已下令限制在政府机构、军事单位和关键基础设施内使用 Telegram 消息应用程序。 这一消息通过NCCC的官方 Facebook 账号对外发布,在公告中乌…...
[SDX35]SDX35如何查看GPIO的Base值
SDX35 SDX35介绍 SDX35设备是一种多模调制解调器芯片,支持 4G/5G sub-6 技术。它是一个4nm芯片专为实现卓越的性能和能效而设计。它包括一个 1.9 GHz Cortex-A7 应用处理器。 SDX35主要特性 ■ 3GPP Rel. 17 with 5G Reduced Capability (RedCap) support. Backward compati…...

【Linux学习】【Ubuntu入门】2-1-1 vim编辑器设置
设置TAB键为4字节及显示行号 VIM编辑器默认TAB键为8空格,改为4空格 输入命令sudo vi /etc/vim/vimrc回车后输入密码按键盘下键到最后,按下“a”进入编辑模式,输入set ts4设置为4空格下一行输入set nu显示行号...

全栈开发(一):springBoot3+mysql初始化
1.开发环境准备 1.开发工具 2.jdk下载 官网下载java17 3.java环境变量配置 用户变量: ①.JAVA_HOME ②.path 4.mysql下载 b站随便搜 5.新建项目 6.maven配置 可以下载zip放到目录里 这里是配置好的 repository文件夹:为maven提供下载的文件存放…...

有关若依登录过程前端的对应处理学习
导言 在用C#搞完个后端后想用若依的前端做对接,不过很久没搞过若依了,想趁这个二次开发的过程记录熟悉一下登录的过程 过程 验证,在permission.js的路由守卫,这里在用户发起api请求时会验证用户的请求是否有token,对…...
django使用笔记6--docker部署
django使用笔记--docker部署 多环境配置创建环境变量配置文件静态资源配置dockerfile配置 由于服务器中python版本和依赖与本地开发环境不同,且centOS7中python及依赖安装更新较为麻烦,所以采用docker容器部署 多环境配置 多环境配置类似Spring中的多环…...

高性能、高可靠,MK SD卡让数据存储无忧!
文章目录 SD卡(Secure Digital Memory Card),作为当代数字生活中不可或缺的存储媒介,凭借其卓越的数据传输效率、灵活的热插拔功能以及惊人的存储容量,在多个领域大放异彩。从日常使用的智能手机、平板电脑到追求极致体…...

NetAssist测试TCP和UDP
由于在Windows下经常使用NetAssist.exe这款网络调试工具进行TCP、UDP的服务端、客户端的监听,对于需要编写各种通信协议的TCP服务端、客户端以及UDP通信程序来说是很方便的。下载地址:http://free.cmsoft.cn/download/cmsoft/assistant/netassist5.0.14.…...
mcuboot使用介绍
准备工作 硬件平台选择 确保你的微控制器单元(MCU)是 MCUboot 所支持的类型。查看 MCUboot 的文档或官方支持列表,了解其兼容的 MCU 系列和硬件平台。根据硬件平台的设计,将微控制器与相关的外设(如闪存、通信接口等&a…...
如何在 Linux 终端使用 GET 和 POST 请求
文章目录 1、GET请求基本请求带有请求头带有参数将响应保存成文件 2、POST请求基本请求发送JSON格式的POST请求体使用文件作为POST请求体使用时注意 1、GET请求 基本请求 在Linux中,发送GET请求通常使用 curl 命令,curl 的默认行为就是发送GET请求&…...
主从数据库同步配置详解(MySQL/MariaDB)
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、环境准备与安装配置本地部署MySQLUbuntu 系统:CentOS 系统: MariaDBUbuntu 系统:CentOS 系统: 容器部署MySQ…...

台式机通过笔记本上网
概述: ①将wifi共享给网口 ②网口配置成自协商IP和DNS即可 一、背景 由于台式机只有网口,没得wifi网卡,因此想通过笔记本连wifi,再通过网线将笔记本和台式机连接起来,从而实现台式机通过笔记本的wifi上网,即让笔记本当台式机的…...
golang雪花算法实现64位的ID
推荐学习文档 golang应用级os框架,欢迎stargolang应用级os框架使用案例,欢迎star案例:基于golang开发的一款超有个性的旅游计划app经历golang实战大纲golang优秀开发常用开源库汇总想学习更多golang知识,这里有免费的golang学习笔…...
LeetCode 137. 只出现一次的数字 II
LeetCode 137. 只出现一次的数字 II 给你一个整数数组 nums ,除某个元素仅出现 一次 外,其余每个元素都恰出现 三次 。请你找出并返回那个只出现了一次的元素。 你必须设计并实现线性时间复杂度的算法且使用常数级空间来解决此问题。 示例 1:…...

新书推荐——《深度学习精粹与PyTorch实践》
深度学习绝非不可窥探的黑箱!深入理解其模型和算法的实际运作机制,是驾驭并优化结果的关键。你无需成为数学专家或资深数据科学家,同样能够掌握深度学习系统内部的工作原理。 本书旨在通过深入浅出的方式,为你揭示这些原理,让你在理解和解释…...

Docker:解决开发运维问题的开源容器化平台
云计算de小白 Docker是一个开源的容器化平台,可以将应用程序及其依赖的环境打包成轻量级、可移植的容器。 Docker为什么这么受欢迎呢?原因很简单:Docker可以解决不同环境一致运行的问题,而且占用资源少,速度快。 所以好的东西…...
多线程计算π
1、实现单线程计算π 2、使用任务分解方法,使用2线程,并行计算π 3、使用数据分解方法,使用2线程,并行计算π 注意:在循环中使用以上计算π的公式,n取值为1到Int.Max 问题1: import java.lang.*;public class Thread1 extends Thread{@Overridepublic void run(){l…...

JAVA开源项目 足球俱乐部管理后台 计算机毕业设计
博主说明:本文项目编号 T 051 ,文末自助获取源码 \color{red}{T051,文末自助获取源码} T051,文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析…...
QMC5883L的驱动
简介 本篇文章的代码已经上传到了github上面,开源代码 作为一个电子罗盘模块,我们可以通过I2C从中获取偏航角yaw,相对于六轴陀螺仪的yaw,qmc5883l几乎不会零飘并且成本较低。 参考资料 QMC5883L磁场传感器驱动 QMC5883L磁力计…...

无法与IP建立连接,未能下载VSCode服务器
如题,在远程连接服务器的时候突然遇到了这个提示。 查阅了一圈,发现是VSCode版本自动更新惹的祸!!! 在VSCode的帮助->关于这里发现前几天VSCode自动更新了,我的版本号变成了1.100.3 才导致了远程连接出…...

《用户共鸣指数(E)驱动品牌大模型种草:如何抢占大模型搜索结果情感高地》
在注意力分散、内容高度同质化的时代,情感连接已成为品牌破圈的关键通道。我们在服务大量品牌客户的过程中发现,消费者对内容的“有感”程度,正日益成为影响品牌传播效率与转化率的核心变量。在生成式AI驱动的内容生成与推荐环境中࿰…...
OkHttp 中实现断点续传 demo
在 OkHttp 中实现断点续传主要通过以下步骤完成,核心是利用 HTTP 协议的 Range 请求头指定下载范围: 实现原理 Range 请求头:向服务器请求文件的特定字节范围(如 Range: bytes1024-) 本地文件记录:保存已…...
C# SqlSugar:依赖注入与仓储模式实践
C# SqlSugar:依赖注入与仓储模式实践 在 C# 的应用开发中,数据库操作是必不可少的环节。为了让数据访问层更加简洁、高效且易于维护,许多开发者会选择成熟的 ORM(对象关系映射)框架,SqlSugar 就是其中备受…...

智能仓储的未来:自动化、AI与数据分析如何重塑物流中心
当仓库学会“思考”,物流的终极形态正在诞生 想象这样的场景: 凌晨3点,某物流中心灯火通明却空无一人。AGV机器人集群根据实时订单动态规划路径;AI视觉系统在0.1秒内扫描包裹信息;数字孪生平台正模拟次日峰值流量压力…...

C++:多态机制详解
目录 一. 多态的概念 1.静态多态(编译时多态) 二.动态多态的定义及实现 1.多态的构成条件 2.虚函数 3.虚函数的重写/覆盖 4.虚函数重写的一些其他问题 1).协变 2).析构函数的重写 5.override 和 final关键字 1&#…...
纯 Java 项目(非 SpringBoot)集成 Mybatis-Plus 和 Mybatis-Plus-Join
纯 Java 项目(非 SpringBoot)集成 Mybatis-Plus 和 Mybatis-Plus-Join 1、依赖1.1、依赖版本1.2、pom.xml 2、代码2.1、SqlSession 构造器2.2、MybatisPlus代码生成器2.3、获取 config.yml 配置2.3.1、config.yml2.3.2、项目配置类 2.4、ftl 模板2.4.1、…...

android RelativeLayout布局
<?xml version"1.0" encoding"utf-8"?> <RelativeLayout xmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"match_parent"android:layout_height"match_parent"android:gravity&…...
MySQL 主从同步异常处理
阅读原文:https://www.xiaozaoshu.top/articles/mysql-m-s-update-pk MySQL 做双主,遇到的这个错误: Could not execute Update_rows event on table ... Error_code: 1032是 MySQL 主从复制时的经典错误之一,通常表示ÿ…...