openstack介绍及原理
openstack介绍及原理
文章目录
- 什么是openstack
- 云计算模式
- OpenStack 中有哪些项目?
- Openstack创建实例的流程
- 总图
- openstack项目搭建:
什么是openstack
云计算模式
一、IaaS:基础设施即服务(个人比较习惯的):用户通过网络获取虚机、存储、网络,然后用户根据自己的需求操作获取的资源 openstack
二、PaaS:平台即服务:将软件研发平台作为一种服务, 如Eclipse/Java编程平台,服务商提供编程接口/运行平台等
三、SaaS:软件即服务 :将软件作为一种服务通过网络提供给用户,如web的电子邮件、HR系统、订单管理系统、客户关系系统等。用户无需购买软件,而是向提供商租用基于web的软件,来管理企业经营活动
OpenStack 中有哪些项目?
- keystone:Keystone 认证所有 OpenStack 服务并对其进行授权。同时,它也是所有服务的端点目录。
- glance:Glance 可存储和检索多个位置的虚拟机磁盘镜像。
- nova:是一个完整的 OpenStack 计算资源管理和访问工具,负责处理规划、创建和删除操作。
- neutron:Neutron 能够连接其他 OpenStack 服务并连接网络。
- dashboard:web管理界面
- Swift: 是一种高度容错的对象存储服务,使用 RESTful API 来存储和检索非结构数据对象。
- Cinder 通过自助服务 API 访问持久块存储。
- Ceilometer:计费
- Heat:编排
Openstack创建实例的流程
通过登录界面dashboard或命令行CLI通过
RESTful API
向keystone
获取认证信息。keystone
通过用户请求认证信息,并生成auth-token
返回给对应的认证请求。
3.然后携带auth-token
通过RESTful API
向nova-api
发送一个boot instance
的请求。
4 nova-api
接受请求后向keystone
发送认证请求,查看token是否为有效用户和token。- 5 keystone验证token是否有效,将结果返回给
nova-api
。
- 6.通过认证后nova-api和数据库通讯,初始化新建虚拟机的数据库记录。
7 nova-api
调用rabbitmq
,向nova-scheduler
请求是否有创建虚拟机的资源(node主机)。8 nova-scheduler
进程侦听消息队列,获取nova-api的请求。
9 nova-scheduler
通过查询nova数据库中计算资源的情况,并通过调度算法计算符合虚拟机创建需要的主机。10 对于有符合虚拟机创建的主机,
nova-scheduler
更新数据库中虚拟机对应的物理主机信息。
11 nova-scheduler
通过rpc调用向nova-compute
发送对应的创建虚拟机请求的消息。
nova-compute
会从对应的消息队列中获取创建虚拟机请求的消息。
12 nova-compute
通过rpc调用向nova-conductor
请求获取虚拟机消息。(Flavor)
nova-conductor
从消息队队列中拿到nova-compute
请求消息。
13 nova-conductor
根据消息查询虚拟机对应的信息。
nova-conductor
从数据库中获得虚拟机对应信息。
14 nova-conductor
把虚拟机信息通过消息的方式发送到消息队列中。
nova-compute
从对应的消息队列中获取虚拟机信息消息。
15 nova-compute
请求glance-api
获取创建虚拟机所需要镜像。
16 glance-api
向keystone
认证token是否有效,并返回验证结果。
- 17 token验证通过,
nova-compute
获得虚拟机镜像信息(URL)。
18 nova-compute
请求neutron-server
获取创建虚拟机所需要的网络信息。19 neutron-server
向keystone认证token是否有效,并返回验证结果。- 20 token验证通过,
nova-compute
获得虚拟机网络信息。
21 nova-compute
请求cinder-api
获取创建虚拟机所需要的持久化存储信息。22 cinder-api
向keystone认证token是否有效,并返回验证结果。- 23 token验证通过,
nova-compute
获得虚拟机持久化存储信息。
24 nova-compute
根据instance的信息调用配置的虚拟化驱动来创建虚拟机。
总图
2.Apl请求发送消息队列 进行调度scheduler(Apl接受请求,写到数据库中)
3.调度结果放到队列中 分配到主机上的任务 分配到哪台机器哪台机器取这个调度结果消息
1.客户(可以是OpenStack最终用户,也可以是其他程序)向API(nova-api)发送请求:“帮我创建一个虚机”;
2.API对请求做一些必要处理后,向Messaging(RabbitMQ)发送了一条消息:“让Scheduler创建一个虚机”;
3.Scheduler(nova-scheduler)从Messaging获取到API发给它的消息,然后执行调度算法,从若干计算节点中选出节点 A ;
4.Scheduler向Messaging发送了一条消息:“在计算节点 A 上创建这个虚机”
5.计算节点 A 的Compute(nova-compute)从Messaging中获取到Scheduler发给它的消息,然后在本节点的Hypervisor上启动虚机;
6.在虚机创建的过程中,Compute如果需要查询或更新数据库信息,会通过Messaging向Conductor(nova-conductor)发送消息,Conductor负责数据库访问。
openstack项目搭建:
openstack介绍及原理相关推荐
- Openstack组件实现原理 — Nova 体系结构
目录 目录 前文列表 Nova体系结构 虚拟机实例化流程 前文列表 Openstack组件部署 - Overview和前期环境准备 Openstack组建部署 - Environment of Con ...
- 【ironic】ironic介绍与原理
[ironic]ironic介绍与原理 零,配置文件 0.1 配置驱动 文件ironic.conf, ipmi硬件类型,默认值也是ipmi, pxe_ipmitool驱动也是默认值,配置驱动 [DEF ...
- OpenStack介绍说明、OpenStack架构说明、OpenStack核心服务详细说明【keystone,nova,cinder,neutron...】、OpenStack创建VM,服务间交互示例
文章目录 OpenStack介绍说明 OpenStack起源 认识openstack[重要] OpenStack架构说明 OpenStack架构概览 OpenStack逻辑架构 OpenStack生产 ...
- 【Ceph】Ceph介绍、原理、架构
目录 理解Ceph的三种存储接口:块设备.文件系统.对象存储 干货|非常详细的 Ceph 介绍.原理.架构 1. Ceph架构简介及使用场景介绍 1.1 Ceph简介 1.2 Ceph特点 1.3 C ...
- AbstractQueuedSynchronizer的介绍和原理分析
简介 提供了一个基于FIFO队列,可以用于构建锁或者其他相关同步装置的基础框架.该同步器(以下简称同步器)利用了一个int来表示状态,期望它能够成为实现大部分同步需求的基础.使用的方法是继承,子类通过 ...
- 【helpdesk】启明星helpdesk7.0版本里,实现邮件提交功能介绍和原理
在启明星helpdesk7.0版本里,新增了一个功能:邮件提交.所谓邮件提交就是用户直接发送邮件到IT.当然IT通常会公开一个公共邮件,例如support@dotnetcms.org.下面介绍一下启明 ...
- 文档下载:《两万字深度介绍分布式系统原理》.pdf
墨天轮文档:<两万字深度介绍分布式系统原理!>:https://www.modb.pro/doc/2028(复制到浏览器中打开或者点击"阅读原文"进行下载) 由于篇幅有 ...
- (一)云计算OpenStack介绍
目录 什么是OPENSTACK? 云计算的前世今生 OpenStack 简介 1.什么是云计算 3.OpenStack 4.Opens tack历史 5.OpenStack社区与链接 OPENSTAC ...
- Attension Mechanism模型的详细介绍,原理、分类及应用
模型汇总24 - 深度学习中Attention Mechanism详细介绍:原理.分类及应用 Attention是一种用于提升基于RNN(LSTM或GRU)的Encoder + Decoder模型的效 ...
最新文章
- debian安装oracle jdk
- GIT Windows服务端搭建笔记
- 搜索 —— 启发式搜索 —— A* 算法
- do…while 第二讲
- linux 查看最近用户,Linux下查看用户列表
- svg 动画_svg 动画介绍(一)
- JVM初识之类加载过程
- linux系统——hadoop环境搭建
- 编程必备基础知识-计算机组成原理-01概述篇-笔记
- 数据挖掘与分析应用2:大厂制作周报报表制作方法与标准格式,联动使用index和match配合sumif和sumifs函数
- 如何更改python界面颜色_pycharm修改界面主题颜色的方法 pycharm怎么恢复默认设置...
- oracle 建立分区,oracle 分区表的建立方法
- 理解elasticsearch
- JAVA知识体系之分布式篇(七)——Redis
- 复旦大学高等代数考试命题的若干经验
- Python为什么要使用包管理、插件化开发?
- Mapreduce圳鹏数据
- Ubuntu紫色背景颜色代码
- opencv3.4.1: ippicv_2017u3_lnx_intel64_20170822.tgz下载包
- 一种伪DNA密码学方法
热门文章
- linux取消bios密码设置密码,简单五步设置BIOS密码使电脑更安全
- ChatGlm-6B多张显卡的web_demo.py
- 阿里云从零单排搭建环境
- 短视频推广转到直播领域,探店达人做好直播的秘诀是什么
- 马列主义告诉我们:物质基础决定上层建筑 - 移动互联网时代之后的时代演进推断...
- 如何使用canvas画玫瑰图
- python交互式程序设计导论第五周小测试答案_20145209刘一阳《JAVA程序设计》第五周课堂测试...
- c语言写排行榜(只保留前五名的数据)
- 电脑如何截屏?用什么快捷键?
- Centos 配置yum 的几种方式、