Attach Volume 操作(Part II) - 每天5分钟玩转 OpenStack(54)

Posted CloudMan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Attach Volume 操作(Part II) - 每天5分钟玩转 OpenStack(54)相关的知识,希望对你有一定的参考价值。

技术分享

上一节我们讨论了 attach volume 操作中 cinder-api 的工作,本节讨论 cinder-volume 和 nova-compute 如何将 volume attach 到 Instance。

cinder-volume 初始化 volume 的连接

cinder-volume 接收到 initialize_connection 消息后,会通过 tgt 创建 target,并将 volume 所对应的 LV 通过 target export 出来。日志为 /opt/stack/logs/c-vol.log

技术分享

下面的日志显示:通过命令 tgtadm --lld iscsi --op show --mode target 看到已经将 1GB(1074MB)的 LV /dev/stack-volumes-lvmdriver-1/volume-1e7f6bd7-ce11-4a73-b95e-aabd65a5b188 通过 Target 1 export 出来了。

技术分享

Initialize connection 完成。

技术分享

nova-compute 将 volume attach 到 instance

计算节点作为 iSCSI initiator 访问存储节点 Iscsi Target 上的 volume,并将其 attach 到 instance。日志文件为 /opt/stack/logs/n-cpu.log

技术分享

nova-compute 依次执行 iscsiadm 的 new, update, login, rescan 操作访问 target 上的 volume。

技术分享

技术分享

技术分享

技术分享

计算节点将 iSCSI target 上的 volume 识别为一个磁盘文件。

技术分享

然后通过更新 instance 的 XML 配置文件将 volume 映射给 instance。

技术分享

我们也可以通过 virsh edit 查看更新后的 XML。 技术分享

可以看到,instance 增加了一个类型为 block 的虚拟磁盘,source 就是要 attach 的 volume,该虚拟磁盘的设备名为 vdb。

手工 Shut off 并 Start instance,通过 fdisk -l 查看到 volume 已经 attach 上来,设备为 vdb

技术分享

GUI 界面也会更新相关 attach 信息

技术分享

现在如果我们在存储节点执行 tgt-admin --show --mode target,会看到计算节点作为 initiator 已经连接到 target 1。cinder-volume 刚刚创建 target 的时候是没有 initiator 连接的,大家可以将下面的截图与之前的日志做个对比。

技术分享

以上就是 attach volume 的全部内容,下一节我们讨论 detach 操作。

 

技术分享

以上是关于Attach Volume 操作(Part II) - 每天5分钟玩转 OpenStack(54)的主要内容,如果未能解决你的问题,请参考以下文章

Attach Volume 操作(Part II) - 每天5分钟玩转 OpenStack(54)

Attach Volume 操作(Part I) - 每天5分钟玩转 OpenStack(53)

Attach Volume 操作(Part I) - 每天5分钟玩转 OpenStack(53)

Create Volume 操作(Part II) - 每天5分钟玩转 OpenStack(51)

Create Volume 操作(Part II) - 每天5分钟玩转 OpenStack(51)

Extend Volume 操作 - 每天5分钟玩转 OpenStack(56)