openstack中创建一个虚拟机经过的51步

一、前言

本文在林海峰老师“openstack创建一个VM所需的29步”基础上进行了补充和修改,文中只用到了openstack六个核心组件,为了便于理解,架构中不同组件内的rabbit mq和db为同一个(可以为每个组件配置单独的db和rabbit mq)。openstack组件之间通过REST调用,组件内通过RPC协议通信,RPC协议又是基于AMQP模型实现的,rabbit mq就是运用该模型的一款软件。

二、概述

以现实中的PC举例来说明openstack创建的VM,一个PC要能正常工作它需要具备:计算单元、系统、网络和存储单元这四个基本要素,对应openstack中实现该功能的组件分别为:nova、glance、neutron和cinder,以下就详细说明一个VM创建时所经过的具体步骤。

三、创建VM的过程详解


上图是openstack上发起一个创建VM请求到VM创建完成的全过程,以下对上述51步进行详细解释:

  1. 用户通过horizon或者cli发起一个创建VM请求时,首先去keystone进行认证;
  2. 认证通过后,keystone将结果返回给用户,其中就包含用户权限的token令牌;
  3. 用户通过token像nova-api发起创建虚拟机的而请求;
  4. nova-api首先去keystone验证用户的token是否有效;
  5. keystone将认证后的结果返回给nova-api;
  6. nova-api将用户要创建VM的信息,如CPU、内存、网络及硬盘等存入数据库;
  7. 存储完成后,数据库将结果返回给nova-api;
  8. nova-api将要创建VM的信息扔到消息队列;
  9. nova-scheduler从消息队列中接收到该信息;
  10. nova-shceduler从数据库中查询可承载VM的物理服务器;
  11. 数据库将可用的物理服务器反馈给nova-scheduler,它根据权重最终选出1台物理机承载VM;
  12. nova-scheduler将最终承载VM的物理机信息扔到消息队列;
  13. 被选中物理服务器上的nova-compute接收到该消息;
  14. nova-compute将查询请求扔到消息队列,请求获得用户需要创建VM的flavor类型;
  15. nova-conductor从消息队列中接收到请求。该组件的作用是防止VM在被攻破后被当作跳板直接***数据库,大规模环境下,该组件可能会成为瓶颈;
  16. nova-conductor去数据库查询用户要创建的flavor类型;
  17. 数据库将查询到的结果反馈给nova-conductor;
  18. nova-conductor将用户需要创建VM的flavor类型扔到消息队列;
  19. nova-conpute获取到flavor类型,至此,nova-compute知道用户需要创建的VM都需要包含哪些资源;
  20. nova-compute向glance-api发起获取镜像请求;
  21. glance-api向keystone进行认证;
  22. keystone将认证后的结果返回给glance-api(glance组件之间通信不经过rabbit mq);
  23. glance-api将任务交由glance-registry处理,glance-registry负责存储系统镜像的元数据;
  24. glance-registry向db查询创建VM需要的镜像及镜像的存放位置;
  25. glance-registry将结果返回给glance-api;
  26. glance-api去存放镜像的对象存储上获取镜(此处的glance模式是V1版本,在V2版本中取消了glance-registry,glance-api直接连db和image store);
  27. glance-api将获取到的镜像结果反馈给nova-compute,至此,系统镜像已具备;
  28. nova-compute向neutron-server发起创建网络请求(neutron-server此处就是起到api的作用,只是名字不叫api);
  29. neutron-server去keystone进行认证;
  30. neutron-server将需要创建网络的请求扔到消息队列;
  31. neutron-plugins从消息队列中接收到该请求;
  32. neutron-plugins去db中获取要创建的网络使用的plugin以及要创建网络的网络类型和机制类型;
  33. neutron-plugins将获取到的信息扔到消息队列;
  34. neutron-agents从消息队列收到该信息后执行网络创建;
  35. neutron-agents将创建的相关信息保存到数据库中;
  36. neutron-agents创建完成后将消息扔到消息队列;
  37. neutron-server从消息队列中收到创建完成的信息;
  38. neutron-server将该信息反馈给nova-compute,至此,网络条件具备;
  39. nova-compute向cinder-api发起持久存储的请求;
  40. cinder-api首先会去keystone进行身份认证;
  41. 认证通过后将需要创建持久化存储的信息扔到消息队列;
  42. cinder-scheduler从消息队列中接收到信息;
  43. cinder-scheduler去db上查询哪些物理主机可以提供持久存储,并根据权中选取出1台;
  44. cinder-scheduler将结果扔到消息队列;
  45. 被选中主机上的cinder-volume接收到该消息;
  46. cinder-volume调用后端存储驱动,创建持久化存储设备,如LVM等;
  47. cinder-volume将创建好的持久化存储信息存到数据库中;
  48. cinder-volume将创建好的结果扔到消息队列;
  49. cinder-api从消息队列中接收到该消息;
  50. cinder-api将该消息反馈给nova-compute,至此,一个VM所需要的计算、系统镜像、网络、存储四个基本条件都已具备;
  51. nova-compute调用hypervisor创建VM,hypervisor可以是KVM、XEN、VMware等。

以上就是openstack中一个VM从用户发起请求到创建所需要经历的步骤,如果用到的组件不止示例中的四个,依然是nova-compute向相应组件的api发起请求,待所有条件都具备后,再调用hypervisor创建VM。

原文地址:http://blog.51cto.com/arkling/2329742

时间: 2024-10-05 23:37:32

openstack中创建一个虚拟机经过的51步的相关文章

在sql server中创建一个只读login

在SQL Server中创建一个Login,并为这个login授予只读的权限 --create Login Name create login [domain\login] from windows; --create --UserName Create User DWReadOnly for login [domain\login] --Grant readonly ALTER ROLE [db_datareader] add MEMBER DWReadOnly Appendix 服务器角色参

在windows中创建一个影子用户

在windows中创建一个影子用户(看不到图请下载附件) 我们可以在windows操作系统中建立一个影子用户,也就是它是实际存在的,但是不会在登录时或者用户组中显示,我们可以赋予影子用户管理员权限,可以在某些情况下管理员不可用时使用. 建立影子用户之前,我们先介绍几个概念: SAM数据库:对用户登录用户名和密码进行验证. 注册表:相当于windows的神经系统,很重要. 策略管理器:它实际是注册表的管理工具,因为直接修改注册表是困难和危险的. 下面我们创建影子用户: 1)影子用户名称必须以$结尾

【实战】在BingoCloudOS中创建一个blog环境

本文通过实战方式了解下在品高云(BingoCloudOS)中如何快速部署一个wordpress的blog站点(包括web和数据库) 涉及服务:弹性服务器(EC2) 涉及版本:所有版本 涉及功能点:镜像.密钥.远程连接.安全组.存储卷.wordpress下载与安装 1.创建实例前的准备 1.1.准备镜像 系统镜像由云平台管理员在进行云平台初始化时准备,普通用户直接使用即可,用户对于需要的镜像可在[基础服务→计算→镜像]的搜索内容框中对镜像进行搜索,若云平台中暂无您需要的镜像时可向管理员申请,或基于

iOS9中怎样在日历App中创建一个随意时间之前開始的提醒(三)

大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 假设认为写的不好请多提意见,假设认为不错请多多支持点赞.谢谢! hopy ;) 四.创建随意时间之前開始的提醒 如今我们找到了指定源中的指定日历,剩下要做的就是在日历中创建一个事件,而且设置其对于的提醒.我们能够创建2种类型的事件:单一的和循环的(或者称之为反复的).这里为了简单起见(KISS),我们仅仅创建单一的事件: -(void)addAlarmToCalendar:(EKCalendar*)calendar inStore:(EK

【Unity Shaders】Reflecting Your World —— 在Unity3D中创建一个简单的动态Cubemap系统

本系列主要参考<Unity Shaders and Effects Cookbook>一书(感谢原书作者),同时会加上一点个人理解或拓展. 这里是本书所有的插图.这里是本书所需的代码和资源(当然你也可以从官网下载). ========================================== 分割线 ========================================== 写在前面 我们已经学了很多关于反射的内容,但是我们现在的反射并不能实时反射,即当反射物体移动时它们不

在挂起的进程中创建一个远程线程

以挂起状态创建一个进程 invoke CreateProcess, NULL, szPath, NULL, NULL, FALSE, CREATE_SUSPENDED, NULL, NULL, addr @si, addr @pi 在该进程中创建一个远程线程 invoke CreateRemoteThread, hProcess, NULL, 0, eax, NULL, NULL, NULL 如果在恢复主线程之前,远程线程退出了,程序就会退出或没有界面(XP下会有这个问题,WIN7不会出现).

在存放源程序的文件夹中建立一个子文件夹 myPackage。例如,在“D:\java”文件夹之中创建一个与包同名的子文件夹 myPackage(D:\java\myPackage)。在 myPackage 包中创建一个YMD类,该类具有计算今年的年份、可以输出一个带有年月日的字符串的功能。设计程序SY31.java,给定某人姓名和出生日期,计算该人年龄,并输出该人姓名、年龄、出生日期。程序使用YM

题目补充: 在存放源程序的文件夹中建立一个子文件夹 myPackage.例如,在"D:\java"文件夹之中创建一个与包同名的子文件夹 myPackage(D:\java\myPackage).在 myPackage 包中创建一个YMD类,该类具有计算今年的年份.可以输出一个带有年月日的字符串的功能.设计程序SY31.java,给定某人姓名和出生日期,计算该人年龄,并输出该人姓名.年龄.出生日期.程序使用YMD的方法来计算年龄. 主要考包的运用 用到java.util.Calendar

openstack创建一个虚拟机的过程

为什要用云? 一.简单的说就是对资源更加合理的分配,使用,比如硬件的数量,带宽等等这些,因为你不能机器买来不需要了再卖掉(当然也可以),带宽跟机房签合同得来一年的,中间不够了也不能加,超了也不退钱 二.还有就是可以有一个可以统一管理的操作平台,可以快速的对基础设施进行建设配置等等,方便了许多 云计算是个什么鬼? 资源可以循环利用的一个过程(PS:没有虚拟化就没有云,因此这两者没什么可比性) 现有云模式(复制大神的): 一.IaaS:基础设施即服务(个人比较习惯的):用户通过网络获取虚机.存储.网

在OpenStack环境中创建一个VM实例

在OpenStack平台上创建一个VM实例,在OpenStack组件间一般会经历以下过程: 以某个有创建VM权限的账户登录到OpenStack环境(Web环境或者命令行环境):账户发起创建VM的请求,Keystone认证通过后发给该账户token:账户凭token调用nova-api创建VM:nova-api将账户户要创建的VM资源信息发给nova-scheduler,由nova-scheduler调度VM承载机器:承载机器上的nova-compute从nova-conductor处获得flav