openstack中创建一个虚拟机经过的51步 原创 qiao645 2018-12-13 00:21:20 博主文章分类:OpenStack ©著作权 文章标签 openstack 虚拟机 文章分类 OpenStack 云计算 ©著作权归作者所有:来自51CTO博客作者qiao645的原创作品,请联系作者获取转载授权,否则将追究法律责任 一、前言 本文在林海峰老师“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步进行详细解释: 用户通过horizon或者cli发起一个创建VM请求时,首先去keystone进行认证; 认证通过后,keystone将结果返回给用户,其中就包含用户权限的token令牌; 用户通过token像nova-api发起创建虚拟机的而请求; nova-api首先去keystone验证用户的token是否有效; keystone将认证后的结果返回给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的flavor类型; nova-conductor从消息队列中接收到请求。该组件的作用是防止VM在被攻破后被当作跳板直接攻击数据库,大规模环境下,该组件可能会成为瓶颈; nova-conductor去数据库查询用户要创建的flavor类型; 数据库将查询到的结果反馈给nova-conductor; nova-conductor将用户需要创建VM的flavor类型扔到消息队列; nova-conpute获取到flavor类型,至此,nova-compute知道用户需要创建的VM都需要包含哪些资源; nova-compute向glance-api发起获取镜像请求; glance-api向keystone进行认证; keystone将认证后的结果返回给glance-api(glance组件之间通信不经过rabbit mq); glance-api将任务交由glance-registry处理,glance-registry负责存储系统镜像的元数据; glance-registry向db查询创建VM需要的镜像及镜像的存放位置; glance-registry将结果返回给glance-api; glance-api去存放镜像的对象存储上获取镜(此处的glance模式是V1版本,在V2版本中取消了glance-registry,glance-api直接连db和image store); glance-api将获取到的镜像结果反馈给nova-compute,至此,系统镜像已具备; nova-compute向neutron-server发起创建网络请求(neutron-server此处就是起到api的作用,只是名字不叫api); neutron-server去keystone进行认证; neutron-server将需要创建网络的请求扔到消息队列; neutron-plugins从消息队列中接收到该请求; neutron-plugins去db中获取要创建的网络使用的plugin以及要创建网络的网络类型和机制类型; neutron-plugins将获取到的信息扔到消息队列; neutron-agents从消息队列收到该信息后执行网络创建; neutron-agents将创建的相关信息保存到数据库中; neutron-agents创建完成后将消息扔到消息队列; neutron-server从消息队列中收到创建完成的信息; neutron-server将该信息反馈给nova-compute,至此,网络条件具备; nova-compute向cinder-api发起持久存储的请求; cinder-api首先会去keystone进行身份认证; 认证通过后将需要创建持久化存储的信息扔到消息队列; cinder-scheduler从消息队列中接收到信息; cinder-scheduler去db上查询哪些物理主机可以提供持久存储,并根据权中选取出1台; cinder-scheduler将结果扔到消息队列; 被选中主机上的cinder-volume接收到该消息; cinder-volume调用后端存储驱动,创建持久化存储设备,如LVM等; cinder-volume将创建好的持久化存储信息存到数据库中; cinder-volume将创建好的结果扔到消息队列; cinder-api从消息队列中接收到该消息; cinder-api将该消息反馈给nova-compute,至此,一个VM所需要的计算、系统镜像、网络、存储四个基本条件都已具备; nova-compute调用hypervisor创建VM,hypervisor可以是KVM、XEN、VMware等。 以上就是openstack中一个VM从用户发起请求到创建所需要经历的步骤,如果用到的组件不止示例中的四个,依然是nova-compute向相应组件的api发起请求,待所有条件都具备后,再调用hypervisor创建VM。 赞 收藏 评论 分享 举报 上一篇:几句话说清Bash Shell环境变量 下一篇:说清楚讲明白vxlan在openstack中的使用场景 提问和评论都可以,用心的回复会被更多人看到 评论 发布评论 全部评论 () 最热 最新 相关文章 Python创建交互式网络图 一、背景女朋友有一天提出了奇怪的要求,让我给她整一张主要城市的交互式网络图,我都给忘记了,可是她却记着呢,这就来问我要啦来嘛,我这就整起:使用Python创建交互式网络图二、步骤准备使用pyvis库来制作,先安装pip install pyvis生成城市列表准备了一个城市字符串,split即可得到城市列表# 生成城市列表city_str = "上海 北京 深圳 重庆 广州 成都 天津 武汉 Python 交互式网络图 pyvis Spring MVC 源码分析 - 一个请求的旅行过程 在上一篇《WebApplicationContext 容器的初始化》文档中分析了 Spring MVC 是如何创建两个容器的,其中创建Root WebApplicationContext 后,调用其refresh()方法会触发刷新事件,完成 Spring IOC 初始化相关工作,会初始化各种 Spring Bean 到当前容器中,该系列文档暂不分析我们先来了解一个请求是如何被 Sprin MVC 初始化 解析器 一个线程,从“生”到“死”经历的过程 通用的线程生命周期总体上可以分为五个状态:初始状态、可运行状态、运行状态、休眠状态和终止状态。 Java 生命周期 休眠状态 线程生命周期 Openstack nova、glance、keystone命令学习 显示nova服务列表:nova service-list+----+------------------+--------+----------+---------+-------+----------------------------+-----------------+| Id | Binary & 命令 openstack openstack glance 命令创建一个虚拟机 # OpenStack Glance命令创建虚拟机## 引言OpenStack是一个开源的云计算平台,它提供了一系列的服务来管理虚拟机实例、网络、存储等资源。其中,Glance是OpenStack中负责虚拟机镜像管理的组件,它允许用户上传、下载、共享和注册虚拟机镜像。本文将介绍如何使用OpenStack Glance命令来创建一个虚拟机实例。我们将使用Glance的命令行工具来上传并注 上传 创建虚拟机 命令行工具 OpenStack(i版)之Keystone,Glance,Nova,Neutron,Horizon Neutron,Horizon i版 Keystone Glance Openstack针对nova,cinder,glance使用ceph的虚拟机创建机制优化 . 今天在开源中国社区看到有如下一个问题:已经成功把ceph作为cinder和 glance的后端,但是如果作为nova的后端,虚拟机启动速度非常慢,网上查了一下是因为openstack创建虚拟机的时候通过ceph取镜像创建虚拟机再把虚拟机存回ceph的步骤浪费了很多时间,是否有办法不把镜像取到本地,而是直接在ceph的存储池里完成虚拟机的创建呢?实际上,我当前也是把ceph作为nova,c openstack glance cinder nova 启动虚拟机过程(转载) [一条nova boot引发的血案]nova boot –flavor 1 –key_name mykey –p_w_picpath 9e5c2bee-0373-414c-b4af-b91b0246ad3b –security_group default cirrOSnova命令来自python-novaclient[到python-novaclient]寻找最开始的源先到这里python-nov openstack问题 1.创建虚拟机实例: 使用OpenStack的Nova模块,开发一个应用程序,允许用户创建和管理虚拟机实例。 创建一个能够让用户通过OpenStack Nova模块创建和管理虚拟机实例的应用程序需要一些复杂的步骤。这里,我将提供一个简化的示例来演示这个概念。实际上,你需要搭建OpenStack环境,设置认证,以及更多的工作才能建立一个完整的虚拟机管理应用。以下是一个简化的Python示例,使用OpenStack SDK创建虚拟机实例。首先,确保你已经安装了OpenStack SDK。如果没有,你可以使用以 创建虚拟机 python 配置文件 创建一个VMware Workstation虚拟机 实验要求:创建一个VMware Workstation虚拟机实验步骤:1. 打开VMwareWorkstation软件2. 点击创建新的虚拟机 3. 选择自定义然后点下一步 4. 继续下一步 &nb 虚拟机 openstack-nova-虚拟机创建流程以及源码分析(一) openstack 虚机创建流程以及源码分析(一)基于openstack stein虚机创建流程图上图是虚拟机创建流程的整体流程,可以看到整体虚拟机创建流程一次经过了API、Conductor、Scheduler、Placement、Compute等主要服务。下表列出了每个步骤中实例的状态:StatusTaskPower stateStepsBuildschedulingNone3-12Build 创建虚拟机 数据库 openstack nova Nova虚拟机启动 虚拟机接入OVS是如何实现的?既然流表是为了虚拟机通信用的,那么没有虚拟机的接入,流表也就没有了用武之地。因此,本节就来讲一讲OpenStack中虚拟机启动过程中,是如何获取MAC、IP地址,如何在Neutron上绑定port,以及如何获取IP地址的。这一节就当做是对上一节“Neutron的软件实现”的一个补充吧。从头开始讲。虚拟机的启动通常来自于控制节点命令行的novaboot,该命令被组装成R java nova虚拟机启动拉取image的过程 这里只关注Nova virt的spawn函数,glance、nova后端为cephnova/virt/libvirt/driver.py def spawn(self, context, instance, p_w_picpath_meta, injected_files, & nova ceph 解决Horizon、Keynote、Nova、Neutron、Cinder、Swift、Glance、Ceilmeter组件的具体操作步骤 ## OpenStack 组件的实现流程OpenStack 是一个开源的云计算平台,由多个组件组成。在这篇文章中,我将教你如何实现 OpenStack 中的 Horizon、Keynote、Nova、Neutron、Cinder、Swift、Glance 和 Ceilmeter 组件。### 实施步骤下面是实施这些组件的步骤的表格:| 步骤 | 组件名称 | 代码操作 || -- git bash Cinder 虚拟机 裸金属架构 虚拟机组件 虚拟机文件组成VMware将一台台的虚拟机封装成一个文件夹到数据存储中 在虚拟机完成安装,正常开机,未做快照、挂起等操作时,虚机文件如下:开机状态下.vmdk 该文件是虚拟机的磁盘文件,它储存了虚拟机硬盘驱动器里的信息。 一台虚拟机可以由一个或多个虚拟磁盘文件组成,如果在新建虚拟机时指定虚拟机磁盘文件为单独一个文件时,系统将只创建一个.vmdk文件,该文件包括了虚拟机磁盘分区信息,以及虚拟机磁盘的 虚拟机 裸金属架构 vmware 知识点 虚拟磁盘 虚拟内存 创建一个独立的Android虚拟机 创建虚拟机软件 1.虚机部署:所需软件下载: 首先下载软件:VMware 你可以选择虚机试centos/windows系统,下面演示centos系统的虚机: 下载centos , 并找到文件对应的路径。 2.我已VMware 12 版本为例 下载好VMware 之后,可以先搜索一个12版本的注册码。 例如:注册码: 5A02H-AU243-TZJ49-GTC7K-3C61N 3.找到VMware 所在的文 创建一个独立的Android虚拟机 vmware 虚拟机 centos 注册码 创建一个swift项目 介绍一下,用 Xcode 开发一个 完整的 Mac桌面程序 Demo。 工具/原料 Mac系统 Xcode软件 创建项目 1 打开 Xcode 2 创建一下新的项目 3 选择项目类型 4 填写项目基本信息 5 项目存放位置,选择在 Documents/mac 没有 mac 目录,就新建立一个 6 创 xcode 创建项目 mac系统 [Swift] 创建一个对象 创建一个对象先写一个People类//// People.swift// Class//// Created by YouXianMing on 15/3/18.// Copyright (c) 2015年 YouXianMing. All rights reserved.//import ... Swift iOS swift ide 初始化 swift 创建一个异步串行 swift创建对象 swift中创建对象,即PUT object,根据选定的存储策略将对象内容写入至相应的服务器(object server)。我们重点关注object controller和object servers之间的通信过程,其它从略。 在proxy-server上对client发送来的HTTP请求进行解析、wsgi环境变量进行设置、认证及相应错误处理过程从略。唯一需要说明的是,对外部client 通过HT swift 创建一个异步串行 swift HTTP 结点 openstack nova 创建虚机 openstack创建虚拟机流程 1. 概述Nova是OpenStack中处理计算业务(虚拟机、裸机、容器)的组件,整体的虚拟机创建流程自然是学习和熟悉Nova组件的第一步。本篇文章主要基于OpenStack Pike版本,基于最新的Cell v2架构部署为例,来介绍虚拟机的创建流程,并分析了Pike等最近几个版本中,虚拟机创建流程的关键变化。2. 虚拟机创建流程上图是虚拟机创建流程的整体流程,可以看到整体虚拟机创建流程一次经过了 openstack nova 创建虚机 运维 数据库 json API