[BugFix][Devref] Refactor attach/detach v2 devref
There are some issues around new attach/detach APIs/CLIs, fix them step by step. Currently the attach/detach dev ref is out of date and have some format issues. Refactor attach/detach v2 devref to make it more readable. This is the original version: [1] DocImpact Depends-On: bae8bd017e30425295e03d13b39202a81e923c3e Closes-Bug: 1675976 [1] https://docs.openstack.org/developer/cinder/devref/attach_detach_conventions_v2.html Change-Id: I26f8427b38ee08c5da7224df6423956ee9a744d2
This commit is contained in:
parent
504f129714
commit
e5c45ffbaf
@ -22,7 +22,7 @@ a bit vague and we have a number of race issues during the calls that
|
|||||||
continually cause us some problems.
|
continually cause us some problems.
|
||||||
|
|
||||||
Additionally, the existing code path makes things like multi-attach extremely
|
Additionally, the existing code path makes things like multi-attach extremely
|
||||||
difficult to implement due to no real good tracking mechansim of attachment
|
difficult to implement due to no real good tracking mechanism of attachment
|
||||||
info.
|
info.
|
||||||
|
|
||||||
To try and improve this we've proposed a new Attachments Object and API. Now
|
To try and improve this we've proposed a new Attachments Object and API. Now
|
||||||
@ -42,15 +42,18 @@ connector information for an Attachment so we no longer have the problem of
|
|||||||
lost connector info, or trying to reassemble it.
|
lost connector info, or trying to reassemble it.
|
||||||
|
|
||||||
New API and Flow
|
New API and Flow
|
||||||
=================
|
================
|
||||||
|
|
||||||
|
attachment-create
|
||||||
|
-----------------
|
||||||
|
|
||||||
```
|
```
|
||||||
attachment_create <instance_uuid> <volume_id>
|
attachment-create <volume-id> <instance-uuid>...
|
||||||
```
|
```
|
||||||
|
|
||||||
The attachment_create call simply creates an empty Attachment record for the
|
The attachment_create call simply creates an empty Attachment record for the
|
||||||
specified Volume with an optional Instance UUID field set. This is
|
specified Volume with an Instance UUID field set. This is particularly
|
||||||
particularly useful for cases like Nova Boot from Volume where Nova hasn't sent
|
useful for cases like Nova Boot from Volume where Nova hasn't sent
|
||||||
the job to the actual Compute host yet, but needs to make initial preparations
|
the job to the actual Compute host yet, but needs to make initial preparations
|
||||||
to reserve the volume for use, so here we can reserve the volume and indicate
|
to reserve the volume for use, so here we can reserve the volume and indicate
|
||||||
that we will be attaching it to <Instance-UUID> in the future.
|
that we will be attaching it to <Instance-UUID> in the future.
|
||||||
@ -75,62 +78,75 @@ The attachment_create call can be used in one of two ways:
|
|||||||
attachment_create call and the Cinder API will perform the reserve and
|
attachment_create call and the Cinder API will perform the reserve and
|
||||||
initialize the connection in the single request.
|
initialize the connection in the single request.
|
||||||
|
|
||||||
|
This full usage of attachment-create would be::
|
||||||
|
|
||||||
|
usage: cinder --os-volume-api-version 3.27 attachment-create
|
||||||
|
<volume-id> <instance-uuid>...
|
||||||
|
|
||||||
param instance-uuid: The ID of the Instance we'll be attaching to
|
Positional arguments:
|
||||||
param volume-id: The ID of the volume to reserve an Attachment record for
|
<volume-id>: The ID of the volume to create attachment for
|
||||||
rtyp: string:`VolumeAttachmentID`
|
<instance-uuid>: The ID of the Instance we'll be attaching to
|
||||||
|
|
||||||
|
Optional arguments:
|
||||||
|
--connect <connect> Make an active connection using provided connector info (True or False)
|
||||||
|
--initiator <initiator> iqn of the initiator attaching to
|
||||||
|
--ip <ip> ip of the system attaching to
|
||||||
|
--host <host> Name of the host attaching to
|
||||||
|
--platform <platform> Platform type
|
||||||
|
--ostype <ostype> OS type
|
||||||
|
--multipath <multipath> Use multipath
|
||||||
|
--mountpoint <mountpoint> Mountpoint volume will be attached at
|
||||||
|
|
||||||
|
Returns the connection information for the attachment::
|
||||||
|
|
||||||
|
+-------------------+-----------------------------------------------------------------------+
|
||||||
|
| Property | Value |
|
||||||
|
+-------------------+-----------------------------------------------------------------------+
|
||||||
|
| access_mode | rw |
|
||||||
|
| attachment_id | 6ab061ad-5c45-48f3-ad9c-bbd3b6275bf2 |
|
||||||
|
| auth_method | CHAP |
|
||||||
|
| auth_password | kystSioDKHSV2j9y |
|
||||||
|
| auth_username | hxGUgiWvsS4GqAQcfA78 |
|
||||||
|
| encrypted | False |
|
||||||
|
| qos_specs | None |
|
||||||
|
| target_discovered | False |
|
||||||
|
| target_iqn | iqn.2010-10.org.openstack:volume-23212c97-5ed7-42d7-b433-dbf8fc38ec35 |
|
||||||
|
| target_lun | 0 |
|
||||||
|
| target_portal | 192.168.0.9:3260 |
|
||||||
|
| volume_id | 23212c97-5ed7-42d7-b433-dbf8fc38ec35 |
|
||||||
|
+-------------------+-----------------------------------------------------------------------+
|
||||||
|
|
||||||
|
attachment-update
|
||||||
|
-----------------
|
||||||
|
|
||||||
```
|
```
|
||||||
cinder --os-volume-api-version 3.27 attachment-create --instance <instance-uuid> <volume-id>
|
cinder --os-volume-api-version 3.27 attachment-update <attachment-id>
|
||||||
```
|
```
|
||||||
|
|
||||||
param volume_id: The ID of the volume to create attachment for.
|
Once we have a reserved a volume, this CLI can be used to update an attachment for a cinder volume.
|
||||||
parm attachment_id: The ID of a previously reserved attachment.
|
This call is designed to be more of an attachment completion than anything else.
|
||||||
|
It expects the value of a connector object to notify the driver that the volume is going to be
|
||||||
|
connected and where it's being connected to. The usage is the following::
|
||||||
|
|
||||||
param connector: Dictionary of connection info
|
usage: cinder --os-volume-api-version 3.27 attachment-update
|
||||||
param mode: `rw` or `ro` (defaults to `rw` if omitted).
|
<attachment-id> ...
|
||||||
param mountpoint: Mountpoint of remote attachment.
|
|
||||||
rtype: :class:`VolumeAttachment`
|
|
||||||
|
|
||||||
Example connector:
|
Positional arguments:
|
||||||
{'initiator': 'iqn.1993-08.org.debian:01:cad181614cec',
|
<attachment-id> ID of attachment
|
||||||
'ip':'192.168.1.20',
|
|
||||||
'platform': 'x86_64',
|
|
||||||
'host': 'tempest-1',
|
|
||||||
'os_type': 'linux2',
|
|
||||||
'multipath': False}
|
|
||||||
|
|
||||||
```
|
|
||||||
cinder --os-volume-api-version 3.27 attachment-create --initiator iqn.1993-08.org.debian:01:29353d53fa41 --ip 1.1.1.1 --host blah --instance <instance-id> <volume-id>
|
|
||||||
```
|
|
||||||
|
|
||||||
Returns a dictionary including the connector and attachment_id:
|
|
||||||
|
|
||||||
```
|
|
||||||
+-------------------+-----------------------------------------------------------------------+
|
|
||||||
| Property | Value |
|
|
||||||
+-------------------+-----------------------------------------------------------------------+
|
|
||||||
| access_mode | rw |
|
|
||||||
| attachment_id | 6ab061ad-5c45-48f3-ad9c-bbd3b6275bf2 |
|
|
||||||
| auth_method | CHAP |
|
|
||||||
| auth_password | kystSioDKHSV2j9y |
|
|
||||||
| auth_username | hxGUgiWvsS4GqAQcfA78 |
|
|
||||||
| encrypted | False |
|
|
||||||
| qos_specs | None |
|
|
||||||
| target_discovered | False |
|
|
||||||
| target_iqn | iqn.2010-10.org.openstack:volume-23212c97-5ed7-42d7-b433-dbf8fc38ec35 |
|
|
||||||
| target_lun | 0 |
|
|
||||||
| target_portal | 192.168.0.9:3260 |
|
|
||||||
| volume_id | 23212c97-5ed7-42d7-b433-dbf8fc38ec35 |
|
|
||||||
+-------------------+-----------------------------------------------------------------------+
|
|
||||||
```
|
|
||||||
|
|
||||||
|
Optional arguments:
|
||||||
|
--initiator <initiator> iqn of the initiator attaching to
|
||||||
|
--ip <ip> ip of the system attaching to
|
||||||
|
--host <host> Name of the host attaching to
|
||||||
|
--platform <platform> Platform type
|
||||||
|
--ostype <ostype> OS type
|
||||||
|
--multipath <multipath> Use multipath
|
||||||
|
--mountpoint <mountpoint> Mountpoint volume will be attached at
|
||||||
|
|
||||||
attachment-delete
|
attachment-delete
|
||||||
=================
|
-----------------
|
||||||
|
|
||||||
```
|
```
|
||||||
cinder --os-volume-api-version 3.27 attachment-delete 6ab061ad-5c45-48f3-ad9c-bbd3b6275bf2
|
cinder --os-volume-api-version 3.27 attachment-delete <attachment-id>
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user