General Contents

Glance detailed explanation and installation

1. Component description

Glance Service Functions

• The OpenStack Image Service (Glance) enables users to discover, register, and retrieve vm images (.img files) The image service allows users to query VM image metadata and retrieve an actual image file. Whether it is a simple file system or OpenStack object storage, you can use the image service to store VM images in different locations. The uploaded VM image is stored in /var/lib/glanc/images/

Glance-api: an API interface used to receive image discovery, retrieval, and storage glance-Registry: used to store, process, and retrieve image metadata. Metadata contains the size and type of the object. Glance-registry is an internal service used by the OpenStack image service and is not disclosed to users. Database: Specifies the size and type of the metadata used to store the image. Most databases are supportedforImage Files: store image files. Supports various types of storage including common file systems. These storage devices include object storage, block device, HTTP, and Amazon S3. However, some storage devices only support read-only accessCopy the code

2. Basic concepts

Image Identifiers: Image urls in /images/ are globally unique

Imestatus: Specifies the ID of the image. Specifies the ID of the image. Specifies the ID of the image

Unstructured Disk Image Format: VMWare, XEN, Microsoft, VirtualBox • VirtualBox, QEMU: Optical disc Qcow2: QEMU: Amazon Kernel Image Amazon machine image

Container Format

3. Component workflow

4. Construct experiments

I. Prerequisites for installation

1A. Log in to the database as database administrator root [root@controller ~]# mysql-uroot -pa Welcome to the MariaDB monitor. Commands endwith ; or \g.
Your MariaDB connection id is 15
Server version: 5.537.-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. MariaDB [(none)]> CREATE DATABASE glance; Query OK,1 row affected (0.00SEC) c. Create user glance and GRANT PRIVILEGES ON glance database 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'@The '%'  IDENTIFIED BY 'GLANCE_DBPASS';
Query OK, 0 rows affected (0.00 sec)


2Run the admin environment script [root@controller ~]# source admin-openrc.sh3A. Create the glance user [root@controller ~]# keystone user-create --name glance --pass GLANCE_PASS +----------+----------------------------------+ | Property | Value | +----------+----------------------------------+ | email | | | enabled | True | | id | aec25e44755d425cb8948bafc47d5071 | | name | glance | | username | glance | +----------+----------------------------------+ b. Link the glance user to the service tenant and the admin role [root@controller ~]# keystone user-role-add --user glance --tenant service --role admin c. Create the Glance service [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               |
+-------------+----------------------------------+

4Create authentication service endpoint 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 | + -- -- -- -- -- -- -- -- -- -- -- -- - + -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- + build completeCopy the code

5, test,


 [root@controller images]# yum install -y lrzsz
[root@controller images]# ls
cirros-0.33.-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.33.-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.33.-x86_64                  |
| owner            | dc4de4d7ecda4ed898b5e0d82809d2ad     |
| protected        | False                                |
| size             | 13200896                             |
| status           | active                               |
| updated_at       | 2020-07-24T11:25:09| | virtual_size | None | + -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- - + -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- + testing successCopy the code

Install and configure the image service component

1[root@controller ~]# yum install openstack-glance python-glanceclient2[root@controller ~]# vim /etc/glance/glance-api.conf a. Modify the [database] section to configure the database connection: [database]... connection = mysql://glance:[email protected]/glanceB. Modify section [keystone_AuthToken] and [Paste_Deploy] to configure authentication service access: [keystone_AuthToken]... auth_uri= http:/ / controller.nice.com: 5000 / v2.0
identity_uri= http://controller.nice.com:35357admin_tenant_name= service admin_user= glance admin_password= GLANCE_PASS [paste_deploy] ... Flavor = keystone c. (Optional) Configure detailed log output in section [DEFAULT]. Easy to troubleshoot. [DEFAULT]... verbose = True3, edit the /etc/glance/glance-registry.con file, and complete the following configuration: a. Configure the database connection in the [database] section: [database]... connection = mysql://glance:[email protected]/glanceB. In the [keystone_AuthToken] and [Paste_Deploy] sections, configure the authentication service to access [keystone_AuthToken]... auth_uri= http:/ / controller.nice.com: 5000 / v2.0
identity_uri= http://controller.nice.com:35357admin_tenant_name= service admin_user= glanceadmin_password= GLANCE_PASS[paste_deploy]... Flavor = keystone c. In section [glance_store], configure a path for storing the local file system and image files. default_store= filefile system_store_datadir=/var/Lib /glance/images/ d. (Optional) Configure detailed log output in section [DEFAULT]. Easy to troubleshoot. [DEFAULT] ... verbose = True4[root@controller ~]# su -s /bin/sh -c"glance-manage db_sync"Glance Starts the image service and sets it to automatically start upon startup:  [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 The meanings of the image-create options are as follows: --name < name > Image name. --file < file > File and path to be uploaded. --disk-format <DISK_FORMAT> Disk format of the mirror. Can support: AMI, ARI, AKI, VHD, VMDK, RAW, Qcow2, VDI, ISO format. --container-format <CONTAINER_FORMAT> Image container format. Can support: AMI, ARI, AKI, bare, OVF format. --is-public {True,False} Whether the image can be publicly accessed. [root@controller images]# glance image-list +--------------------------------------+---------------------+-------------+------------------+----------+--------+ | ID  | Name | Disk Format | Container Format | Size | Status | +--------------------------------------+---------------------+-------------+------------------+----------+--------+ | 807f460b-566a-4989-b166-dc83248d4a40 | cirros-0.33.-x86_64 | qcow2       | bare             | 13200896 | active |
+--------------------------------------+---------------------+-------------+------------------+----------+--------+

Copy the code