openstack-cinder之generic volume
N版本之后cinder提供了generic volume group,通用卷组功能,官方文档:走你!
N版本之前cinder提供的是一致性组
(consistency group),但是一致性组的功能只有一部分的driver支持,那么cinder中的组有哪些功能:
- 通过一致性组可以对组内的块存储进行统一的操作,保证数据的一致性
- 可以把一类或者某个应用使用的多个块归到一个组中,便于管理
之前的一致性组中的某一个块的驱动不支持一致性组功能,那么就没有什么意义了,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_at
与updated_at
是一样的。
就酱紫,记录下这个功能基本用法,遗留问题:
- group的spec能否对volume设置qos
- 代码解析
碎觉去!