Create volume¶
Overview¶
Creates a volume.
Classification¶
Create
API Operation Object¶
volumes
Synchronous / Asynchronous¶
asynchronous
Request¶
HTTP Request Method¶
POST
HTTP Request Path¶
{api_endpoint}/v2/{tenant_id}/volumes
HTTP Request Header¶
Format¶
Accept-Encoding: gzip, deflate, compress(optional)
Accept: application/json
X-Auth-Token: <token_id>
Content-Type: application/json
HTTP Request Body¶
Format¶
{
"volume": {
"availability_zone": "<availability_zone>",
"description": "<description>",
"name": "<display_name>",
"imageRef": "<image_id>",
"metadata": <metadata>,
"size": <volume_size>,
"snapshot_id": "<snapshot_id>",
"volume_type": "<volume_type_name>"
}
}
Request Parameter¶
name |
style |
format |
description |
required/optional |
default value |
action for invalid parameter |
response code for invalid parameter |
---|---|---|---|---|---|---|---|
tenant_id |
URL |
UUID(3) |
The unique identifier of the tenant. |
required |
- |
Terminate |
404 |
token_id |
Header |
String(token_id) |
Keystone admin token |
required |
- |
Terminate |
401 |
description |
Body |
String(0-255characters) or null or number(0-255digits) |
The volume description |
optional |
null |
Terminate |
400 |
display_name |
Body |
String(0-255characters) or null or number(0-255digits) |
The volume name |
optional |
null |
Terminate |
400 |
volume_size |
Body |
int(more than 1, Less than the size that is allowed in the Quota) |
The volume size |
required |
- |
Terminate |
400 |
snapshot_id |
Body |
UUID or null |
To create a volume from an existing snapshot, specify the ID of the existing volume snapshot *1 |
optional |
null |
Terminate |
404 |
image_id |
Body |
UUID or null |
Glance image_id which becomes the source data of volume *1 |
optional |
null |
Terminate |
400 |
volume_type_name |
Body |
String or null |
The volume type name |
optional |
Default volume type name *2 |
Terminate |
400 |
metadata |
Body |
Associative array of JSON. ex:{ "key1": "value1", "key2": "value2"} |
One or more metadata key and value pairs to associate with the volume. |
optional |
{} |
Terminate |
400, 500 |
availability_zone |
Body |
availability_zone or null |
availability_zone name |
optional |
Availability zone of this node *3 |
Terminate |
400 |
*1 Specifying simultaneously two or more of the copy source volume ID and image ID and snapshot ID is not allowed.
*2 Default volume type is the value of default_volume_type in conf file.
*3 Default vaule for availability zone is the value of default_availability_zone in conf file. If not set, the value of storage_availability_zone is used as the default for new volumes.
Response¶
HTTP Response Header¶
Format¶
HTTP/1.1 <response code> <message> (ex. 202 Accepted)
<response_code>: see "HTTP Responses" section
<message>: message based on the response code
skip auto insert field such as "X-Compute-Request-Id" and "X-Openstack-Request-Id", "Content-Length", "Date"
Response Code¶
response code |
condition |
---|---|
202 |
normal end |
400 |
There is no HTTP request body, or there is no volume element in the body |
- |
You specify two or more of the copy source volume ID and snapshot ID and Glance Image ID. |
- |
Glance image is specified, part of the image ID that are separated by / if the URI format can not be obtained. |
- |
Image ID the Glance image is specified, were obtained not in the form of UUID |
- |
Volume ID copy source volume ID is specified, were obtained not in the form of UUID |
- |
Status of the snapshot to snapshot ID is specified, the specified is not available |
- |
Status of the volume copy source volume ID is specified, the specified is not available |
- |
The specified size is not an integer value of 1 or more |
- |
Size specified is smaller than the read snapshot of the original |
- |
Size specified is smaller than the read of the original volume |
- |
Bad Request error is encountered in accessing the Glance |
- |
Size of Glance the specified image size is larger than the volume |
- |
The specified volume type does not match the specified copy source volume |
- |
The specified volume type does not match the specified snapshot |
- |
Availability Zone that has been specified does not exist |
- |
specifies invalid parameter |
401 |
unauthorized(including keystone down) |
403 |
When the snapshot ID is specified, user who requested are not allowed to do get_snapshot operation. |
- |
User who requested are not allowed to do create operation |
404 |
Volume type that has been specified does not exist. |
- |
When the snapshot ID is specified, there is no specified snapshot ID. |
- |
Glance image that has been specified does not exist. Or, because the specified glance image is not public in addition to request_user's not having authority of admin, user or project does not have ownership of the image. |
- |
When the copy source volume ID is specified, there is no specified copy source volume image. |
413 |
The specified size exceeds the limit value of Quota. |
- |
The specified number of volume exceeded the limit value of Quota. |
500 |
Access to the Glance image that has been specified is not allowed. |
- |
Endpoint information of Glance is incorrect. |
- |
Failed to communicate with the glance-api. |
- |
The specified metadata is malformed JSON. |
HTTP Response Body¶
Format¶
{
"volume": {
"attachments": [],
"availability_zone": "<availability_zone>",
"created_at": "<created_at>",
"description": "<description>",
"name": "<display_name>",
"id": "<volume_id>",
"image_id": "<image_id>",
"metadata": <metadata>,
"size": <volume_size>,
"snapshot_id": "<snapshot_id>",
"status": "<status>",
"volume_type": "<volume_type>",
"source_volid": "<copy_source_volume>",
"bootable": "<bootable>",
"encrypted":<encrypted>,
"user_id":
"links": [
{
"href": "<volume_URL>",
"rel": "self"
},
{
"href": "<bookmark_URL>",
"rel": "bookmark"
}
],
"user_id": "<user_id>"
}
}
Response Parameter¶
item |
format |
description |
---|---|---|
availability_zone |
String |
The name of availability zone |
created_at |
time/date |
Form: "yyyy-mm-ddThh:mm:ss.ssssss" |
description |
String(0-255characters)or null |
The volume description |
display_name |
String(0-256characters)or null |
The volume name |
volume_id |
UUID |
The volume ID |
metadata |
Associative array of JSON. ex:{ "key1": "value1", "key2": "value2"} |
One or more metadata key and value pairs to associate with the volume. |
volume_size |
int |
The volume size(GB) |
snapshot_id |
UUID or null |
(volume) snapshot ID which becomes the source data of volume |
status |
String |
status of snapshot |
volume_type |
String or null |
The source volume type |
image_id |
UUID or null |
Glance image_id which becomes the source data of volume |
copy_source_volume |
UUID or null |
The volume_id which becomes the source data of volume |
bootable |
false |
|
encrypted |
true or false |
State of encryption |
volume_URL |
URL |
URL of the created volume |
bookmark_URL |
URL |
URL of the bookmark |
user_id |
String(1-255characters) |
The owner of the instance |
Sample API Request and Response¶
Sample API Request¶
Request URI¶
https://example.com/v2/{tenant_id}/volumes
Request Header¶
Accept-Encoding: gzip, deflate, compress(optional)
Accept: application/json
X-Auth-Token: ajk3adjiown02
Content-Type: application/json
Request Body¶
{
"volume": {
"availability_zone": "<availability_zone>",
"description": "<description>",
"name": "<display_name>",
"imageRef": "<image_id>",
"metadata": <metadata>,
"size": <volume_size>,
"snapshot_id": "<snapshot_id>",
"volume_type": "<volume_type_name>"
}
}
Sample API Response¶
Response Header¶
HTTP/1.1 202 Accepted
<response_code>: see "HTTP Responses" section
<message>: message based on the response code
skip auto insert field such as "X-Compute-Request-Id" and "X-Openstack-Request-Id", "Content-Length", "Date"
Response Body¶
{
"volume": {
"attachments": [],
"availability_zone": "<availability_zone>",
"created_at": "<created_at>",
"description": "<description>",
"name": "<display_name>",
"id": "<volume_id>",
"image_id": "<image_id>",
"metadata": <metadata>,
"size": <volume_size>,
"snapshot_id": "<snapshot_id>",
"status": "<status>",
"volume_type": "<volume_type>",
"source_volid": "<copy_source_volume>",
"bootable": "<bootable>",
"encrypted":<encrypted>,
"user_id":
"links": [
{
"href": "<volume_URL>",
"rel": "self"
},
{
"href": "<bookmark_URL>",
"rel": "bookmark"
}
],
"user_id": "<user_id>"
}
}
Execution Example¶
HTTP Request¶
POST /v2/88b6f916fc8a4b81b055aa26993bd68e/volumes HTTP/1.1
User-Agent: curl/7.35.0
Host: 192.168.11.67:8776
Accept-Encoding: gzip, deflate, compress
Accept: application/json
X-Auth-Token: 5dadaaa0620c4c64a2ca0306d487706c
Content-Type: application/json
Content-Length: 212
{"volume": {"status": "creating", "project_id": null, "description": null, "availability_zone": null, "attach_status": "detached", "imageRef": null ,"size": 1, "name": null, "metadata": {}, "volume_type": null}}
HTTP Response¶
HTTP/1.1 202 Accepted
X-Compute-Request-Id: req-e4a420b1-2841-438d-b194-8ee576ab0cc4
Content-Type: application/json
Content-Length: 668
X-Openstack-Request-Id: req-e4a420b1-2841-438d-b194-8ee576ab0cc4
Date: Tue, 27 May 2014 11:17:42 GMT
{"volume": {"status": "creating", "user_id": "360cdc8902e04d4482ab653082b5b5e4", "attachments": [], "links": [{"href": "http://192.168.11.67:8776/v2/88b6f916fc8a4b81b055aa26993bd68e/volumes/e03ee430-3ec1-48bd-ab89-79f604f037fd", "rel": "self"}, {"href": "http://192.168.11.67:8776/88b6f916fc8a4b81b055aa26993bd68e/volumes/e03ee430-3ec1-48bd-ab89-79f604f037fd", "rel": "bookmark"}], "availability_zone": "nova", "bootable": "false", "encrypted": false, "created_at": "2014-05-27T11:17:42.318311", "description": null, "volume_type": null, "name": null, "source_volid": null, "snapshot_id": null, "metadata": {}, "id": "e03ee430-3ec1-48bd-ab89-79f604f037fd", "size": 1}}
Error Execution Example¶
HTTP Request¶
POST /v2/331d0a14a8a34f8996ce2660e0029fef/volumes HTTP/1.1
User-Agent: curl/7.35.0
Host: 192.168.56.250:8776
X-Auth-Token: 150c438fd7234fd095c184ae3b35efad
Content-type: application/json
Accept: application/json
Content-Length: 255
{"volume": {"status": "creating", "project_id": "331d0a14a8a34f8996ce2660e0029fef", "description": null, "availability_zone": null, "attach_status": "detached", "imageRef": null ,"size": 1, "name": "test-volume", "metadata": null, "volume_type": null, }}
HTTP Response¶
HTTP/1.1 400 Bad Request
Content-Length: 66
Content-Type: application/json; charset=UTF-8
X-Compute-Request-Id: req-ee0dab3c-613b-4221-9183-dc7a88b63f80
X-Openstack-Request-Id: req-ee0dab3c-613b-4221-9183-dc7a88b63f80
Date: Thu, 17 Sep 2015 08:04:37 GMT
{"badRequest": {"message": "Malformed request body", "code": 400}}