openstack-cinder之generic volume group(通用卷组)

N版本之后cinder提供了generic volume group,通用卷组功能,官方文档:走你!
N版本之前cinder提供的是一致性组(consistency group),但是一致性组的功能只有一部分的driver支持,那么cinder中的组有哪些功能:

  1. 通过一致性组可以对组内的块存储进行统一的操作,保证数据的一致性
  2. 可以把一类或者某个应用使用的多个块归到一个组中,便于管理

之前的一致性组中的某一个块的驱动不支持一致性组功能,那么就没有什么意义了,generic volume group正是用来解决这个问题,最终提供一个不依赖后端驱动的通用的组功能。

这里主要记录下generic volume group(后面提到的groups即为现在的通用组,consistency group为以前的一致性组)的使用。

基本要素

group某种程度上和volume在使用上是类似的,一个group对应一个group type,group type可以设置key-value的spec(猜测可以在group上直接设置块的qos,有待验证),这和volume很像,一个volume对应一个volume type,对type可以设置qos spec,所以从这样一个角度来看group的操作使用就很了然了创建type,设置spec,创建group,绑定type。group除了对应一个group type之外可以对应多个volume type,毕竟一个group需要关联多个volume。

使用

cinder从V3的API开始支持group操作的,使用命令行的时候可以通过--os-volume-api-version指定具体的版本。group snapshot的版本最早在3.14支持的,这里统一使用3.14.
创建group-type

[/home/cheneydc/workdir]
T_T -> cinder --os-volume-api-version 3.14 group-type-create dc-group-type-1 \
--description "Just for test."                                        
+--------------------------------------+-----------------+----------------+
| ID                                   | Name            | Description    |
+--------------------------------------+-----------------+----------------+
| 493754b4-881c-4482-be19-93966cd17da5 | dc-group-type-1 | Just for test. |
+--------------------------------------+-----------------+----------------+

设置spec

[/home/cheneydc/workdir]
^_^ -> cinder --os-volume-api-version 3.14 \
group-type-key 493754b4-881c-4482-be19-93966cd17da5 \
set name=cheneydc 

T_T -> cinder --os-volume-api-version 3.14 group-specs-list                                                                                        16:14:14 
+--------------------------------------+-----------------+------------------------+
| ID                                   | Name            | group_specs            |
+--------------------------------------+-----------------+------------------------+
| 493754b4-881c-4482-be19-93966cd17da5 | dc-group-type-1 | {u'name': u'cheneydc'} |
+--------------------------------------+-----------------+------------------------+

创建group

[/home/cheneydc/workdir]
^_^ -> cinder --os-volume-api-version 3.14 \
group-create \
493754b4-881c-4482-be19-93966cd17da5 \ # group-type
539394f1-932a-432e-a902-3d223a0873e7  \ # volume-type
--name dc-test-group \
--description "For test" \
--availability-zone nova
+-------------------+-------------------------------------------+
| Property          | Value                                     |
+-------------------+-------------------------------------------+
| availability_zone | nova                                      |
| created_at        | 2017-08-10T16:25:53.000000                |
| description       | For test                                  |
| group_type        | 493754b4-881c-4482-be19-93966cd17da5      |
| id                | c443a28d-7adc-43b9-9204-a814748359b5      |
| name              | dc-test-group                             |
| status            | creating                                  |
| volume_types      | [u'539394f1-932a-432e-a902-3d223a0873e7'] |
+-------------------+-------------------------------------------+

创建volume并添加到group
先创建一个1G大小的volume,t1,并通过指定group id来添加到group当中

[/home/cheneydc/workdir]                                                                                                                           
^_^ -> cinder --os-volume-api-version 3.14 create \
--name t1 1 \
--volume-type 539394f1-932a-432e-a902-3d223a0873e7 \
--group-id c443a28d-7adc-43b9-9204-a814748359b5 
+--------------------------------+--------------------------------------+
| Property                       | Value                                |
+--------------------------------+--------------------------------------+
| attachments                    | []                                   |
| availability_zone              | nova                                 |
| bootable                       | false                                |
| consistencygroup_id            | None                                 |
| created_at                     | 2017-08-10T16:31:55.000000           |
| description                    | None                                 |
| encrypted                      | False                                |
| group_id                       | c443a28d-7adc-43b9-9204-a814748359b5 |
| id                             | 63dc21a3-638d-4ddc-980b-567f6e509fc0 |
| metadata                       | {}                                   |
| migration_status               | None                                 |
| multiattach                    | False                                |
| name                           | t1                                   |
| os-vol-host-attr:host          | None                                 |
| os-vol-mig-status-attr:migstat | None                                 |
| os-vol-mig-status-attr:name_id | None                                 |
| os-vol-tenant-attr:tenant_id   | c9686c9fe293463395cd4bc1f463923b     |
| replication_status             | disabled                             |
| size                           | 1                                    |
| snapshot_id                    | None                                 |
| source_volid                   | None                                 |
| status                         | creating                             |
| updated_at                     | None                                 |
| user_id                        | 2789e352e40643eeab13c6a2bf0c132f     |
| volume_type                    | lvmdriver-1                          |
+--------------------------------+--------------------------------------+

同样的方式再创建一个t2,2G大小的volume,也添加到group中。
创建组快照


[/home/cheneydc/workdir]
^_^ -> cinder --os-volume-api-version 3.14  group-snapshot-create \
--name dc-group-snapshot \
--description "Test for group snapshot" \
c443a28d-7adc-43b9-9204-a814748359b5
+-------------+--------------------------------------+
| Property    | Value                                |
+-------------+--------------------------------------+
| created_at  | 2017-08-10T16:33:15.000000           |
| description | Test for group snapshot              |
| group_id    | c443a28d-7adc-43b9-9204-a814748359b5 |
| id          | bf33528b-f44f-40ca-bcd7-579f0118b8a6 |
| name        | dc-group-snapshot                    |
| status      | creating                             |
+-------------+--------------------------------------+

查看快照列表:

[/home/cheneydc/workdir]
^_^ -> cinder snapshot-list                                                                                                                       
+--------------------------------------+--------------------------------------+-----------+-------------------+------+
| ID                                   | Volume ID                            | Status    | Name              | Size |
+--------------------------------------+--------------------------------------+-----------+-------------------+------+
| 7f22f7ff-e410-4020-82be-939429b2b127 | 2a5df5a4-27fe-4d27-bb9c-5153d94585b3 | available | dc-group-snapshot | 2    |
| a804dc65-5106-4a13-8d9c-dd5bfa738300 | 63dc21a3-638d-4ddc-980b-567f6e509fc0 | available | dc-group-snapshot | 1    |
+--------------------------------------+--------------------------------------+-----------+-------------------+------+

查看具体信息可以看出来,两个快照分别是t1,t2的快照,这里两个快照使用的都是创建group快照时候的name,由于是通过group创建的快照,两个快照是保证了一致性的:

[/home/cheneydc/workdir]
^_^ -> cinder snapshot-show 7f22f7ff-e410-4020-82be-939429b2b127                                                                                   
+--------------------------------------------+--------------------------------------+
| Property                                   | Value                                |
+--------------------------------------------+--------------------------------------+
| created_at                                 | 2017-08-10T16:33:15.000000           |
| description                                | Test for group snapshot              |
| id                                         | 7f22f7ff-e410-4020-82be-939429b2b127 |
| metadata                                   | {}                                   |
| name                                       | dc-group-snapshot                    |
| os-extended-snapshot-attributes:progress   | 100%                                 |
| os-extended-snapshot-attributes:project_id | c9686c9fe293463395cd4bc1f463923b     |
| size                                       | 2                                    |
| status                                     | available                            |
| updated_at                                 | 2017-08-10T16:33:17.000000           |
| volume_id                                  | 2a5df5a4-27fe-4d27-bb9c-5153d94585b3 |
+--------------------------------------------+--------------------------------------+

[/home/cheneydc/workdir]
^_^ -> cinder snapshot-show a804dc65-5106-4a13-8d9c-dd5bfa738300                                                                                   
+--------------------------------------------+--------------------------------------+
| Property                                   | Value                                |
+--------------------------------------------+--------------------------------------+
| created_at                                 | 2017-08-10T16:33:15.000000           |
| description                                | Test for group snapshot              |
| id                                         | a804dc65-5106-4a13-8d9c-dd5bfa738300 |
| metadata                                   | {}                                   |
| name                                       | dc-group-snapshot                    |
| os-extended-snapshot-attributes:progress   | 100%                                 |
| os-extended-snapshot-attributes:project_id | c9686c9fe293463395cd4bc1f463923b     |
| size                                       | 1                                    |
| status                                     | available                            |
| updated_at                                 | 2017-08-10T16:33:17.000000           |
| volume_id                                  | 63dc21a3-638d-4ddc-980b-567f6e509fc0 |
+--------------------------------------------+--------------------------------------+

能看到两个快照的create_atupdated_at是一样的。

就酱紫,记录下这个功能基本用法,遗留问题:

  1. group的spec能否对volume设置qos
  2. 代码解析

碎觉去!

你可能感兴趣的:(openstack-cinder之generic volume group(通用卷组))