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

碎觉去!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,100评论 18 139
  • •王越:VMware存储API整理,比如核心的存储池与卷两者的CURD。可以参考:VMware in OpenSt...
    笨手笨脚越阅读 5,547评论 0 2
  • 第一章 OpenStack基础 OpenStack管理的资源及提供的服务OpenStack做为一个操作系统,...
    sgt_tiger阅读 12,711评论 4 72
  • 创建LVM 划分分区,并指定适合的LVM的ID[root@centos6 rf]# fdisk/dev/sdc使用...
    尘曦的雨阅读 295评论 0 3
  • 说到美食,怎能不提《红楼梦》! 红楼梦是文学的盛宴,亦是众生百态的大集合。读红楼是一件乐事,因为如鲁迅先生所言,能...
    白墨公子阅读 1,220评论 3 12