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 可行性分析…...
基于大模型的 UI 自动化系统
基于大模型的 UI 自动化系统 下面是一个完整的 Python 系统,利用大模型实现智能 UI 自动化,结合计算机视觉和自然语言处理技术,实现"看屏操作"的能力。 系统架构设计 #mermaid-svg-2gn2GRvh5WCP2ktF {font-family:"trebuchet ms",verdana,arial,sans-…...
智慧医疗能源事业线深度画像分析(上)
引言 医疗行业作为现代社会的关键基础设施,其能源消耗与环境影响正日益受到关注。随着全球"双碳"目标的推进和可持续发展理念的深入,智慧医疗能源事业线应运而生,致力于通过创新技术与管理方案,重构医疗领域的能源使用模式。这一事业线融合了能源管理、可持续发…...
在四层代理中还原真实客户端ngx_stream_realip_module
一、模块原理与价值 PROXY Protocol 回溯 第三方负载均衡(如 HAProxy、AWS NLB、阿里 SLB)发起上游连接时,将真实客户端 IP/Port 写入 PROXY Protocol v1/v2 头。Stream 层接收到头部后,ngx_stream_realip_module 从中提取原始信息…...
ArcGIS Pro制作水平横向图例+多级标注
今天介绍下载ArcGIS Pro中如何设置水平横向图例。 之前我们介绍了ArcGIS的横向图例制作:ArcGIS横向、多列图例、顺序重排、符号居中、批量更改图例符号等等(ArcGIS出图图例8大技巧),那这次我们看看ArcGIS Pro如何更加快捷的操作。…...
.Net Framework 4/C# 关键字(非常用,持续更新...)
一、is 关键字 is 关键字用于检查对象是否于给定类型兼容,如果兼容将返回 true,如果不兼容则返回 false,在进行类型转换前,可以先使用 is 关键字判断对象是否与指定类型兼容,如果兼容才进行转换,这样的转换是安全的。 例如有:首先创建一个字符串对象,然后将字符串对象隐…...
Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决
Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决 问题背景 在一个基于 Spring Cloud Gateway WebFlux 构建的微服务项目中,新增了一个本地验证码接口 /code,使用函数式路由(RouterFunction)和 Hutool 的 Circle…...
JS设计模式(4):观察者模式
JS设计模式(4):观察者模式 一、引入 在开发中,我们经常会遇到这样的场景:一个对象的状态变化需要自动通知其他对象,比如: 电商平台中,商品库存变化时需要通知所有订阅该商品的用户;新闻网站中࿰…...
基于 TAPD 进行项目管理
起因 自己写了个小工具,仓库用的Github。之前在用markdown进行需求管理,现在随着功能的增加,感觉有点难以管理了,所以用TAPD这个工具进行需求、Bug管理。 操作流程 注册 TAPD,需要提供一个企业名新建一个项目&#…...
AirSim/Cosys-AirSim 游戏开发(四)外部固定位置监控相机
这个博客介绍了如何通过 settings.json 文件添加一个无人机外的 固定位置监控相机,因为在使用过程中发现 Airsim 对外部监控相机的描述模糊,而 Cosys-Airsim 在官方文档中没有提供外部监控相机设置,最后在源码示例中找到了,所以感…...
Rust 开发环境搭建
环境搭建 1、开发工具RustRover 或者vs code 2、Cygwin64 安装 https://cygwin.com/install.html 在工具终端执行: rustup toolchain install stable-x86_64-pc-windows-gnu rustup default stable-x86_64-pc-windows-gnu 2、Hello World fn main() { println…...
