美文网首页云计算学习
openstack-cinder之generic volume

openstack-cinder之generic volume

作者: cheneydc | 来源:发表于2017-08-11 01:22 被阅读75次

    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. 代码解析

    碎觉去!

    相关文章

      网友评论

      • 开源村osv:你好 我是开源云中文社区的小编 希望能 在我的公众号上转载这篇文章 请问能帮设置一下白名单么?
        cheneydc: @大兴先生 啊 好呀 不过怎么设置呀 我研究下哈

      本文标题:openstack-cinder之generic volume

      本文链接:https://www.haomeiwen.com/subject/vrnkrxtx.html