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

  

一、前言

  

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

  

二,概述

  

以现实中PC举的例来说明openstack创建的虚拟机,一个电脑要能正常工作它需要具备:计算单元,系统,网络和存储单元这四个基本要素,对应openstack中实现该功能的组件分别为:新星,乍看之下,中子和煤渣,以下就详细说明一个VM创建时所经过的具体步骤。

  

三、创建VM的过程详解

  

 openstack中创建一个虚拟机经过的51步”> <br/>上图是openstack上发起一个创建VM请求到VM创建完成的全过程,以下对上述51步进行详细解释:</p>
  <ol>
  <李>用户通过地平线或者cli发起一个创建VM请求时,首先去梯形进行认证;李</>
  <李>认证通过后,重点将结果返回给用户,其中就包含用户权限的令牌令牌,李</>
  <李>用户通过令牌像nova-api发起创建虚拟机的而请求;李</>
  <李> nova-api首先去梯形验证用户的令牌是否有效;李</>
  <李>重点将认证后的结果返回给nova-api;李</>
  <李> nova-api将用户要创建VM的信息,如CPU、内存,网络及硬盘等存入数据库;李</>
  <李>存储完成后,数据库将结果返回给nova-api;李</>
  <李> nova-api将要创建VM的信息扔到消息队列;李</>
  <李> nova-scheduler从消息队列中接收到该信息;李</>
  <李> nova-shceduler从数据库中查询可承载VM的物理服务器;李</>
  <李>数据库将可用的物理服务器反馈给nova-scheduler,它根据权重最终选出1台物理机承载VM,李</>
  <李> nova-scheduler将最终承载VM的物理机信息扔到消息队列;李</>
  <李>被选中物理服务器上的nova-compute接收到该消息,李</>
  <李> nova-compute将查询请求扔到消息队列,请求获得用户需要创建VM的风味类型;李</>
  <李> nova-conductor从消息队列中接收到请求。该组件的作用是防止VM在被攻破后被当作跳板直接* * *数据库,大规模环境下,该组件可能会成为瓶颈;李</>
  <李> nova-conductor去数据库查询用户要创建的风味类型;李</>
  <李>数据库将查询到的结果反馈给nova-conductor;李</>
  <李> nova-conductor将用户需要创建VM的风味类型扔到消息队列;李</>
  <李> nova-conpute获取到风味类型,至此,nova-compute知道用户需要创建的虚拟机都需要包含哪些资源,李</>
  <李> nova-compute向glance-api发起获取镜像请求;李</>
  <李> glance-api向梯形进行认证;李</>
  <李>重点将认证后的结果返回给glance-api(一眼组件之间通信不经过兔子mq);李</>
  <李> glance-api将任务交由glance-registry处理,glance-registry负责存储系统镜像的元数据,李</>
  <李> glance-registry向数据库查询创建VM需要的镜像及镜像的存放位置;李</>
  <李> glance-registry将结果返回给glance-api;李</>
  <李> glance-api去存放镜像的对象存储上获取镜(此处的一瞥模式是V1版本,在V2版本中取消了glance-registry, glance-api直接连db和图像存储);李</>
  <李> glance-api将获取到的镜像结果反馈给nova-compute,至此,系统镜像已具备;李</>
  <李> nova-compute向neutron-server发起创建网络请求(neutron-server此处就是起到api的作用,只是名字不叫api);李</>
  <李> neutron-server去梯形进行认证;李</>
  <李> neutron-server将需要创建网络的请求扔到消息队列;李</>
  <李> neutron-plugins从消息队列中接收到该请求;李</>
  <李> neutron-plugins去数据库中获取要创建的网络使用的插件以及要创建网络的网络类型和机制类型;李</>
  <李> neutron-plugins将获取到的信息扔到消息队列;李</>
  <李> neutron-agents从消息队列收到该信息后执行网络创建;李</>
  <李> neutron-agents将创建的相关信息保存到数据库中,李</>
  <李> neutron-agents创建完成后将消息扔到消息队列;李</>
  <李> neutron-server从消息队列中收到创建完成的信息,李</>
  <李> neutron-server将该信息反馈给nova-compute,至此,网络条件具备;李</>
  <李> nova-compute向cinder-api发起持久存储的请求;李</>
  <李> cinder-api首先会去梯形进行身份认证;李</>
  <李>认证通过后将需要创建持久化存储的信息扔到消息队列;李<h2 class=openstack中创建一个虚拟机经过的51步