Openstack架构构建及详解(3)--Glance组件

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用版 2核4GB 50GB
简介: Openstack架构构建及详解(3)--Glance组件

文章总目录


Glance详解与安装


1、组件说明


Glance 服务功能


•OpenStack镜像服务( glance )使用户能够发现、注册并检索虚拟机镜像( .img文件) •它提供了一个REST API 接口,使用户可以查询虚拟机镜像元数据和检索一个实际的镜像文件 •不论是简单的文件系统还是OpenStack 对象存储,你都可以通过镜像服务在不同的位置存储虚拟机镜像 •默认情况下,上传的虚拟机镜像存储路径为/var/lib/glance/images/


glance-api:一个用来接收镜像发现、检索和存储的API 接口
glance-registry:用来存储、处理和检索镜像的元数据。元数据包含对象的大小和类型。
glance-registry是一个OpenStack镜像服务使用的内部服务,不要透露给用户
Database:用于存储镜像的元数据的大小、类型,支持大多数数据库,一般选择MySQL 或SQLite
Storage repository for image files:镜像文件的存储仓库。支持包括普通文件系统在内的各种存储类型。包括对象存储、块设备、HTTP、Amazon S3,但有些存储只支持只读访问


2、基本概念


Image Identifiers:就是Image URL ,格式/images/全局唯一


ImageStatus➢Queued:镜像ID 已被保留,镜像还没有上传 ➢Saving:镜像正在被上传 ➢Active:镜像可以使用了 ➢Killed:镜像损坏或者不可用 ➢Deleted:镜像被删除


Disk Format➢Raw:This is unstructured disk image format ➢Vhd:VMWare、XEN、Microsoft、VirtualBox ➢Vmdk:common format ➢Vdi:VirtualBox、QEMU emulator ➢ISO:optical disc ➢Qcow2:QEMU emulator ➢Aki:Amazon Kernel Image ➢Ari:Amazon ramdisk image ➢Ami:Amazon machine image


Container Format➢Bare ➢Ovf ➢Aki ➢Ami ➢Ari


3、组件工作流程



image.png



4、构建实验


一、安装先决条件


1、创建数据库
a.以数据库管理员root的身份登录数据库
[root@controller ~]# mysql -uroot -pa
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 15
Server version: 5.5.37-MariaDB MariaDB Server
Copyright (c) 2000, 2014, Oracle, Monty Program Ab and others.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
b.创建glance数据库
MariaDB [(none)]> CREATE DATABASE glance;
Query OK, 1 row affected (0.00 sec)
c.创建数据库用户glance,并授予其对glance数据库的管理权限
MariaDB [(none)]> GRANT ALL PRIVILEGES ON glance.* TO 'glance'@'localhost' IDENTIFIED BY 'GLANCE_DBPASS';
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> GRANT ALL PRIVILEGES ON glance.* TO 'glance'@'%'  IDENTIFIED BY 'GLANCE_DBPASS';
Query OK, 0 rows affected (0.00 sec)
2、启用admin环境脚本
[root@controller ~]# source admin-openrc.sh
3、创建认证服务凭证
a.创建glance用户
[root@controller ~]# keystone user-create --name glance --pass GLANCE_PASS
+----------+----------------------------------+
| Property |              Value               |
+----------+----------------------------------+
|  email   |                                  |
| enabled  |               True               |
|    id    | aec25e44755d425cb8948bafc47d5071 |
|   name   |              glance              |
| username |              glance              |
+----------+----------------------------------+
b.将glance用户链接到service租户和admin角色
[root@controller ~]# keystone user-role-add --user glance --tenant service --role admin
c.创建glance服务
[root@controller ~]# keystone service-create --name glance --type image --description "OpenStackImage Service"
+-------------+----------------------------------+
|   Property  |              Value               |
+-------------+----------------------------------+
| description |      OpenStackImage Service      |
|   enabled   |               True               |
|      id     | 4436c2e4a7c940ea895a3b84484c02a5 |
|     name    |              glance              |
|     type    |              image               |
+-------------+----------------------------------+
4、为OpenStack镜像服务创建认证服务端点admin(管理),internal(内部),public(公共)
[root@controller ~]# keystone endpoint-create --service-id $(keystone service-list |awk '/image/{print $2}') --publicurl http://controller.nice.com:9292 --internalurl http://controller.nice.com:9292 --adminurl http://controller.nice.com:9292 --region regionOne
+-------------+----------------------------------+
|   Property  |              Value               |
+-------------+----------------------------------+
|   adminurl  | http://controller.nice.com:9292  |
|      id     | bb5cce3c4f0f4528812fbb7796ab0f89 |
| internalurl | http://controller.nice.com:9292  |
|  publicurl  | http://controller.nice.com:9292  |
|    region   |            regionOne             |
|  service_id | 4436c2e4a7c940ea895a3b84484c02a5 |
+-------------+----------------------------------+
 构建完成


5、测试


[root@controller images]# yum install -y lrzsz
[root@controller images]# ls
cirros-0.3.3-x86_64-disk.img
[root@controller ~]#  source admin-openrc.sh
[root@controller images]# glance image-create --name "cirros-0.3.3-x86_64" --file cirros-0.3.3-x86_64-disk.img --disk-format qcow2 --container-format bare --is-public True --progress 
[=============================>] 100%
+------------------+--------------------------------------+
| Property         | Value                                |
+------------------+--------------------------------------+
| checksum         | 133eae9fb1c98f45894a4e60d8736619     |
| container_format | bare                                 |
| created_at       | 2020-07-24T11:25:08                  |
| deleted          | False                                |
| deleted_at       | None                                 |
| disk_format      | qcow2                                |
| id               | 807f460b-566a-4989-b166-dc83248d4a40 |
| is_public        | True                                 |
| min_disk         | 0                                    |
| min_ram          | 0                                    |
| name             | cirros-0.3.3-x86_64                  |
| owner            | dc4de4d7ecda4ed898b5e0d82809d2ad     |
| protected        | False                                |
| size             | 13200896                             |
| status           | active                               |
| updated_at       | 2020-07-24T11:25:09                  |
| virtual_size     | None                                 |
+------------------+--------------------------------------+
 测试成功


二、安装并配置镜像服务组件


1、安装软件包
[root@controller ~]# yum install openstack-glance python-glanceclient
2、编辑文件更改配置文件
[root@controller ~]# vim /etc/glance/glance-api.conf
a.修改[database]小节,配置数据库连接:
[database]...
connection = mysql://glance:GLANCE_DBPASS@controller.nice.com/glance
b.修改[keystone_authtoken]和[paste_deploy]小节,配置认证服务访问:[keystone_authtoken]
...
auth_uri= http://controller.nice.com:5000/v2.0
identity_uri= http://controller.nice.com:35357
admin_tenant_name= service
admin_user= glance
admin_password= GLANCE_PASS
[paste_deploy]
...
flavor = keystone
c.(可选)在[DEFAULT]小节中配置详细日志输出。方便排错。[DEFAULT]...verbose = True
3、编辑/etc/glance/glance-registry.con文件,并完成下列配置:
a.在[database]小节中配置数据库连接:
[database]
...
connection = mysql://glance:GLANCE_DBPASS@controller.nice.com/glance
b.在[keystone_authtoken]和[paste_deploy]小节中配置认证服务访问
[keystone_authtoken]
...
auth_uri= http://controller.nice.com:5000/v2.0
identity_uri= http://controller.nice.com:35357
admin_tenant_name= service
admin_user= glanceadmin_password= GLANCE_PASS[paste_deploy]...flavor = keystone
c.在[glance_store]小节中配置本地文件系统存储和镜像文件的存放路径
[glance_store]
...
default_store= filefile
system_store_datadir= /var/lib/glance/images/
d.(可选)在[DEFAULT]小节中配置详细日志输出。方便排错。
[DEFAULT]
...
verbose = True
4、初始化镜像服务的数据库
[root@controller ~]# su -s /bin/sh -c "glance-manage db_sync" glance
启动镜像服务并设置开机自动启动:
[root@controller ~]#  systemctl enable openstack-glance-api.service openstack-glance-registry.service
ln -s '/usr/lib/systemd/system/openstack-glance-api.service' '/etc/systemd/system/multi-user.target.wants/openstack-glance-api.service'
ln -s '/usr/lib/systemd/system/openstack-glance-registry.service' '/etc/systemd/system/multi-user.target.wants/openstack-glance-registry.service'
[root@controller ~]# systemctl start openstack-glance-api.service openstack-glance-registry.service
glance image-create相关选项含义:
--name <NAME>镜像名称。
--file <FILE>要上传文件及路径。
--disk-format <DISK_FORMAT>镜像的磁盘格式。可以支持:ami, ari, aki, vhd, vmdk, raw, qcow2, vdi,iso格式。
--container-format <CONTAINER_FORMAT>镜像容器格式。可以支持:ami, ari, aki, bare, ovf格式。
--is-public {True,False}镜像是否可以被公共访问。
--progress显示上传进度
[root@controller images]# glance image-list
+--------------------------------------+---------------------+-------------+------------------+----------+--------+
| ID                                   | Name                | Disk Format | Container Format | Size     | Status |
+--------------------------------------+---------------------+-------------+------------------+----------+--------+
| 807f460b-566a-4989-b166-dc83248d4a40 | cirros-0.3.3-x86_64 | qcow2       | bare             | 13200896 | active |
+--------------------------------------+---------------------+-------------+------------------+----------+--------+

相关文章
|
6天前
|
运维 Cloud Native 持续交付
探索云原生架构:构建现代应用的基石
【7月更文挑战第9天】本文深入探讨了云原生架构的核心概念、关键技术组件以及实施的最佳实践。通过分析云原生技术如何促进微服务架构的实现,容器化技术的利用,以及持续集成与持续部署(CI/CD)流程的自动化,本文旨在为读者提供一个全面的云原生技术框架视图,并揭示其在加速企业数字化转型过程中的关键作用。
|
3天前
|
消息中间件 Java 开发者
Spring Cloud微服务框架:构建高可用、分布式系统的现代架构
Spring Cloud是一个开源的微服务框架,旨在帮助开发者快速构建在分布式系统环境中运行的服务。它提供了一系列工具,用于在分布式系统中配置、服务发现、断路器、智能路由、微代理、控制总线、一次性令牌、全局锁、领导选举、分布式会话、集群状态等领域的支持。
22 5
|
8天前
|
Prometheus 监控 Kubernetes
如何构建一个可伸缩的微服务架构?
如何构建一个可伸缩的微服务架构?
|
7天前
|
消息中间件 Java 微服务
构建可扩展的Java Web应用架构
构建可扩展的Java Web应用架构
|
7天前
|
Kubernetes Cloud Native 微服务
企业级容器部署实战:基于ACK与ALB灵活构建云原生应用架构
这篇内容概述了云原生架构的优势,特别是通过阿里云容器服务Kubernetes版(ACK)和应用负载均衡器(ALB)实现的解决方案。它强调了ACK相对于自建Kubernetes的便利性,包括优化的云服务集成、自动化管理和更强的生态系统支持。文章提供了部署云原生应用的步骤,包括一键部署和手动部署的流程,并指出手动部署更适合有技术背景的用户。作者建议在预算允许的情况下使用ACK,因为它能提供高效、便捷的管理体验。同时,文章也提出了对文档改进的建议,如添加更多技术细节和解释,以帮助用户更好地理解和实施解决方案。最后,展望了ACK未来在智能化、安全性与边缘计算等方面的潜在发展。水文一篇,太忙了,见谅!
|
7天前
|
Prometheus 监控 Kubernetes
如何构建一个可伸缩的微服务架构?
如何构建一个可伸缩的微服务架构?
|
8天前
|
监控 Java API
使用Spring Boot构建微服务架构的最佳实践
使用Spring Boot构建微服务架构的最佳实践
|
网络协议 Linux 网络安全
openstack 云平台一体化部署(超详细)
openstack 云平台一体化部署(超详细)
1022 0
openstack 云平台一体化部署(超详细)
|
11月前
|
存储 弹性计算 资源调度
openstack组件部署 3
openstack组件部署
102 0
|
2月前
|
存储 Ubuntu KVM
Ubuntu部署OpenStack踩坑指南:还要看系统版本?
Ubuntu部署OpenStack踩坑指南:还要看系统版本?
Ubuntu部署OpenStack踩坑指南:还要看系统版本?