一、 Glance功能

  传统 IT 环境下,安装一个系统是要么从CD安装,要么用 Ghost 等克隆工具恢复。有如下几个问题:

  • 如果要安装的系统多了效率就很低
  • 时间长,工作量大
  • 安装完还要进行手工配置,比如安装其他的软件,设置 IP 等
  • 备份和恢复系统不灵活

  云环境下需要更高效的解决方案,这就是Image。Image是一个模板,里面包含了基本的操作系统和其他的软件。

  Glance提供Image Service服务,功能是管理Image,让用户能够发现、获取和保存Image。

  • 提供REST API让用户能够查询和获取Image的元数据和Image本身。
  • 支持多种方式存储Image,包括普通的文件系统、Swift、Amazon S3等。
  • 对Instance执行Snapshot创建新的Image。

二、 Glance架构

1、各组件的含义

  A client:任何使用Glance服务器的应用程序。

  REST API:Glance提供REST访问的API。

  Database Abstraction Layer (DAL):统一Glance和数据库之间的通信的应用程序编程接口(API)。

  Glance Domain Controller:域控制器,实现主要的中间件功能,如授权,通知,策略,数据库连接。

  Glance Store:用于组织Glance和各种数据存储之间的交互。

  Registry Layer:注册表层,用于通过使用单独的服务来组织域和DAL之间的安全通信的可选层。

  Database:Image的metadata会保持到database中,默认是 MySQL。在控制节点上可以查看glance的database信息。

  Store backend:Glance自己并不存储image。真正的image是存放在backend中的。

图1 Glance的架构

图2 Glance的架构

2、Glance支持多种backend;包括:

  • A directory on a local file system(这是默认配置)
  • GridFS
  • Ceph RBD
  • Amazon S3
  • Sheepdog
  • OpenStack Block Storage (Cinder)
  • OpenStack Object Storage (Swift)
  • VMware ESX

  具体使用哪种backend,是在 /etc/glance/glanceapi.conf中配置的:

[glance_store]
filesystem_store_datadir =

3、镜像磁盘格式

表1 镜像磁盘格式表

类型

说明

raw

This is an unstructured disk image format

vhd

This is the VHDdisk format, a common disk format used by virtual machine monitors from VMWare.

vmdk

Another common disk format supported by many common virtual machine monitors

VDI

A disk format supported by VirtualBox virtual machine monitor and the QEMU

emulator

ISO

An archive format for the data contents of an optical disc(e.g. CDROM)

qcow2

A disk format supported by the QEMU emulator that can expand dynamically and

supports Copy on Write

aki

This indicates what is stored in Glance is an Amazon kernel image

ari

This indicates what is stored in Glance is an Amazon kernel image

armi

This indicates what is stored in Glance is an Amazon kernel image

4、镜像文件的访问权限:

  Public公共的:可以被所有的Tenant使用。

  Private私有的/项目的:只能被Image Owner所在的Tenant使用。

  Shared共享的:一个非公共的Image可以共享给指定的Tenant,通过member-*操作来实现。

  Protected受保护的:Protected Image不能被删除。

5、Image的状态类型:

  Queued:没有上传Image数据,只SQL Database中存有该镜像的元数据(标识该镜像的ID)。

  Saving:标识镜像正在上传Image。

  Active:正常状态,标识镜像在Glance中完全可用。

  Deleted/pending_delete:已删除/等待删除的Image。

  Killed:标识镜像上传过程中出错,Image元数据不正确,镜像完全不可用,等待被删除。

6、创建 Images

  创建Image的两种方法:Web UI(Horizon)和命令行CLI (推荐),API v1已经在Newton版本中被删除了。

  • Web UI的功能没有CLI全,有些操作只提供了CLI。即便是都有的功能,CLI可以使用的参数更多。
  • 一般来说,CLI 返回结果更快,操作起来更高效。
  • CLI 可放在脚本中进行批处理。
  • 有些耗时的操作CLI更合适,比如创建镜像。

图3 Image状态类型

OpenStack-Glance(3)的更多相关文章

  1. 理解 OpenStack + Ceph (5):OpenStack 与 Ceph 之间的集成 [OpenStack Integration with Ceph]

    理解 OpenStack + Ceph 系列文章: (1)安装和部署 (2)Ceph RBD 接口和工具 (3)Ceph 物理和逻辑结构 (4)Ceph 的基础数据结构 (5)Ceph 与 OpenS ...

  2. 探索 OpenStack 之(13):研究 Keystone

    Keystone 是 OpenStack Identity Service 的项目名称.本文就试着尽可能深入地研究 Keystone. 1. Keystone 的功能 做为 OpenStack 云系统 ...

  3. OpenStack 初探(一) -- All-In-One模式部署(初学OpenStack必备)

    OpenStack 初探(一) -- All-In-One模式部署(初学OpenStack必备) 一.操作前需了解:     1. OpenStack提供IaaS(基础设施即服务)服务,它是开源的云计 ...

  4. 探索 OpenStack 之(8):Neutron 深入探索之 OVS + GRE 之 完整网络流程 篇

    前两篇博文分别研究了Compute节点和Neutron节点内部的网络架构.本文通过一些典型流程案例来分析具体网络流程过程. 0. 环境 同 学习OpenStack之(7):Neutron 深入学习之 ...

  5. 学习OpenStack之(6):Neutron 深入学习之 OVS + GRE 之 Compute node 篇

    0.环境 硬件环境见上一篇博客:学习OpenStack之(5):在Mac上部署Juno版本OpenStack 四节点环境 OpenStack网络配置:一个tenant, 2个虚机 Type drive ...

  6. 理解 OpenStack + Ceph (2):Ceph 的物理和逻辑结构 [Ceph Architecture]

    本系列文章会深入研究 Ceph 以及 Ceph 和 OpenStack 的集成: (1)安装和部署 (2)Ceph RBD 接口和工具 (3)Ceph 物理和逻辑结构 (4)Ceph 的基础数据结构 ...

  7. 学习OpenStack之(5):在Mac上部署Juno版本OpenStack 四节点环境

    0. 前沿 经过一段时间的折腾,终于在自己的Mac上装好了Juno版本的四节点环境.这过程中,花了大量的时间,碰到了许多问题,学到不少知识,折腾过不少其实不需要折腾的东西,本文试着来对这过程做个总结. ...

  8. 探索 OpenStack 之(12):cinder-api Service 处理 HTTP Request 的过程分析

    本文是上一篇 探索 OpenStack 之(11):cinder-api Service 启动过程分析 以及 WSGI / Paste deploy / Router 等介绍> 的后续篇. os ...

  9. 探索 OpenStack 之(9):深入块存储服务Cinder (功能篇)

    继研究了Neutron之后,继续Nova的外围研究之旅.本站是研究块存储服务Cinder. 0.验证环境 环境包括: 1.一个controller节点,运行nova-api, nova-schedul ...

  10. 探索 OpenStack 之(10):深入镜像服务Glance

    本篇博文来探讨下镜像服务Glance. 0.  基本概念 0.1 基本功能 Glance提供REST API来支持以下镜像操作: 查询 注册 上传 获取 删除 访问权限管理 0.2 Glance RE ...

随机推荐

  1. python学习笔记(十 二)、操作数据库

    每一种语言都少不了多数据库进行各种操作. python支持多种数据库.有关python支持的数据库清单,请参阅:https://wiki.python.org/moin/DatabaseInterfa ...

  2. Java开发笔记(六十五)集合:HashSet和TreeSet

    对于相同类型的一组数据,虽然Java已经提供了数组加以表达,但是数组的结构实在太简单了,第一它无法直接添加新元素,第二它只能按照线性排列,故而数组用于基本的操作倒还凑合,若要用于复杂的处理就无法胜任了 ...

  3. 【学习笔记】tensorflow队列和线程

    目录 Tensorflow队列 同步执行队列 队列管理器 异步执行队列 线程协调器 在使用TensorFlow进行异步计算时,队列是一种强大的机制. 为了感受一下队列,让我们来看一个简单的例子.我们先 ...

  4. Canvas:时钟

    这个时钟是将钟盘的圆心点移到了 canvas 画布中心点.以方便后面的方位计算 ctx.translate(width/2,height/2); 现定义一个圆盘来显出这个时钟的基本位置 ctx.sav ...

  5. javascript进阶之AJAX

    AJAX 一 AJAX预备知识:json进阶 1.1 什么是JSON? JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.JSON是用字符串来表示Javas ...

  6. RecycleView设置顶部分割线(记录一个坑)

    大家都知道,想给RecycleView设置分割线可以重写RecyclerView.ItemDecoration 项目过程中,遇到一个需求:RecycleView顶部有一条灰色的间隔,我想到了给Recy ...

  7. Servlet工作原理解析 《深入分析java web 技术内幕》第九章

    参考关于servblet的相关文章 侧重概况:https://blog.csdn.net/levycc/article/details/50728921 ibm的相关:https://www.ibm. ...

  8. matlab练习程序(渲染三原色)

    这里我用的空间是x向右为正,y向下为正,z向屏幕里面为正.相当于标准右手系绕x轴旋转了180度. 将三个点光源放在 r = [0.3,0,0.5];g = [0.3,-0.5*cos(pi/6),-0 ...

  9. XPath Helper的安装与使用

    摘要 : XPath Helper可以支持在网页点击元素生成xpath,整个抓取使用了xpath.正则表达式.消息中间件.多线程调度框架的chrome插件. xpath:是一门XML和HTML文档中查 ...

  10. SQLServer之创建分区视图

    分区视图定义 分区视图是通过对成员表使用 UNION ALL 所定义的视图,这些成员表的结构相同,但作为多个表分别存储在同一个 SQL Server实例中,或存储在称为联合数据库服务器的自主 SQL ...