Create server

Overview

Creates a server.

Classification

  • Create

API Operation Object

  • servers

Synchronous / Asynchronous

  • asynchronous

Request

HTTP Request Method

  • POST

HTTP Request Path

{api_endpoint}/v2/{project_id}/servers

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

{
    "server": {
        "OS-DCF:diskConfig": "<disk_config>",
        "flavorRef": "<flavor_id>",
        "imageRef": "<image_id>",
        "max_count": <min_count>,
        "min_count": <max_count>,
        "name": "<instance_name>",
        "availability_zone": "<availability_zone>",
        "config_drive": "<config_drive>",
        "key_name": "<key_name>",
        "user_data": "<user_data>",
        "block_device_mapping": [
             {
                "volume_id": "<volume_id>",
                "delete_on_termination": <delete_flag>,
                "device_name": "<device_name>"
            },
            <<repeat>>
        ],
        "block_device_mapping_v2": [
            {
                "no_device": "<no_device(bdm_v2)>",
                "device_name": "<device_name(bdm_v2)>",
                "source_type": "<source_type(bdm_v2)>",
                "destination_type": "<destination_type(bdm_v2)>",
                "guest_format": "<guest_format(bdm_v2)>",
                "uuid": "<uuid(bdm_v2)>",
                "boot_index": "<boot_index(bdm_v2)>",
                "volume_size": <volume_size(bdm_v2)>,
                "device_type": "<device_type(bdm_v2)>",
                "disk_bus": "<disk_bus(bdm_v2)>",
                "delete_on_termination": <delete_on_termination(bdm_v2)>
            },
            <<repeat>>
        ],
        "metadata": {
               "<metadata_key>": "<metadata_value>",
                <<repeat>>
         },
        "networks": [
           {
              "uuid": "<network_id>",
              "fixed_ip": "<fixed_ip>"
            },
            {
               "port": "<port_id>"
            }
            <<repeat>>
         ],
    }
}

Request Parameter

Request Parameters

name

style

format

description

required/optional

default value

action for invalid parameter

response code for invalid parameter

project_id

URL

UUID(3)

Project id

required

-

Terminate

400, 404

token_id

Header

authentication token string

keystone authentication token

required

-

Terminate

401

disk_config

Body

String (AUTO or MANUAL)

Auto: a single partition which is expanded to the size of the flavor selected

optional

MANUAL

Terminate

400

flavor_id

Body

String(1-255 characters)

flavor id

required

-

Terminate

400

image_id

Body

UUID

image ID

optional (if block_device_mapping_v2 attribute is not specified, it is required)

-

Terminate

400

min_count

Body

int (1-limit of quota)

requested minim count of instance

optional

1

Terminate

400, 403

max_count

Body

int (1-limit of quota)

requested maximum count of instance

optional

min_count

Terminate

400

instance_name

Body

String(1-255 characters)

instance name

required

-

Terminate

400

availability_zone

Body

String(1-255 characters)

availability zone

optional

default availability zone

Terminate

400

config_drive

Body

boolean/UUID(2)

Enables metadata injection in a server through a configuration drive

optional

-

Terminate

400

key_name

Body

String(1-255 characters)

key name

optional

-

Terminate

400

user_data

Body

String(Base64 encoded)

user data

optional

-

Terminate

400

volume_id

Body

UUID

volume id

optional (if block_device_mapping attribute is specified, it is required)

-

Terminate

400

delete_flag

Body

boolean/String('t','true', 'on', 'y', 'yes', '1','f', 'false', 'off', 'n', 'no', '0')

true: delete block device if instance is deleted false: not delete block device even if instance is deleted

optional

false

Terminate

400

device_name

Body

String (^/dev/x{0,1}[a-z]{0,1}d{0,1})([a-z]+)[0-9]*$

device name on Guest OS

optional

/dev/vdb

Terminate

400

no_device(bdm_v2)

Body

boolean/String('t','true', 'on', 'y', 'yes', '1','f', 'false', 'off', 'n', 'no', '0')

disable the specified block_device_mapping_2 Note: unavailable

optional

-

-

-

device_name(bdm_v2)

Body

String (^/dev/x{0,1}[a-z]{0,1}d{0,1})([a-z]+)[0-9]*$

device name on Guest OS

optional

/dev/vdb

Terminate

400

source_type(bdm_v2)

Body

'blank', 'snapshot', 'volume', 'image'

Type of attach source.・Attach Volume = 'volume' ・Attach Snapshot = 'snapshot' ・Attach Image = 'image' ・Attach swap or ephemeral = 'blank'

optional (if block_device_mapping_2 attribute is specified , it is required)

-

Terminate

400

destination_type(bdm_v2)

Body

'local', 'volume'

Type of attach source. ・Attach Volume = 'volume' ・Attach Snapshot = 'volume' ・Attach Image = 'local' or None ・Attach swap or ephemeral = 'local' or None Note: If the combination of source_type and destination_type is invalid, not mapped.", "optional (if block_device_mapping_2 attribute is specified, and if source_type(bdm_v2) is "volume" or "snapshot", it is required)

local

-

-

guest_format(bdm_v2)

Body

String(1-255 characters)

Specifies the guest server disk file system format.・Attach swap = 'swap' ・Attach ephemeral = not 'swap'

optional

-

-

-

uuid(bdm_v2)

Body

UUID

Describes the volume source type for the volume. ・Attach Volume = Volume UUID ・Attach Snapshot = Snapshot UUID ・Attach Image = Image UUID ・Attach swap or ephemeral = None or Omission Note: not specify the uuid of attach already Volume

optional (if block_device_mapping_2 attribute is specified, and if source_type(bdm_v2) is "volume" or "snapshot" or "image", it is required)

-

Terminate

400

boot_index(bdm_v2)

Body

int (0-Number of mapping device)

Indicates a number designating the boot order of the device.

optional(if block_device_mapping_2 attribute is specified , it is required)

-

Terminate

400

volume_size(bdm_v2)

Body

int (0-Maximum value for the 'swap' or 'ephemeral' of flavor that is assigned to the VM)

Size(GB) of the volume(image, snapshot)or ephemeral. also size(MB) of the swap.

optional

0

device_type(bdm_v2)

Body

String('disk', 'cdrom', 'floppy', 'mmc') or None

device type on Guest OS

optional

disk

-

-

disk_bus(bdm_v2)

Body

String('ide', 'usb', 'virtio', 'scsi') or None

disk bus type

optional

hypervisor driver chooses a suitable default

-

-

delete_on_termination(bdm_v2)

Body

boolean/String('t','true', 'on', 'y', 'yes', '1','f', 'false', 'off', 'n', 'no', '0')

true: delete block device if instance is deleted false: not delete block device even if instance is deleted

optional

false

Terminate

400

metadata_key

Body

String(1-255 characters)

key for metadata Server Metadata

optional

-

Terminate

400

metadata_value

Body

String(1-255 characters)

value for metadata Server Metadata

optional

-

Terminate

400

network_id

Body

UUID

network id

optional (if a tenant has more than two networks, it is required)

default network

Terminate

400

fixed_ip

Body

String(IP address)

fixed ip

optional

-

Terminate

400

port_id

Body

UUID

port id

optional(if networks attribute is specified and network_id isn't specified, it is required)

-

Terminate

400

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 "Content-Length", "Date"

Response Code

Response Codes

response code

condition

202

normal end

400

not found server entity in body

-

not found name attribute in body

-

not found flavorRef attribute in body

-

specify invalid block device name

-

specify invalid instance_name (empty or more than 255 caharactors)

-

specify invalid flavor_id

-

specify invalid image_Ref

-

specify invalid port

-

specify invalid network uuid

-

specify invalid fixed_ip

-

specify invalid max_count

-

specify invalid min_count

-

min_count > max_count

-

can't attach volume if min_count >1 or max_count>1

-

can't specify port if min_count >1 or max_count >1

-

specify invalid availability_zone

-

fixed ip is in-use

-

max_count cannot be greater than 1 if an fixed_ip is specified

-

specify invalid metadata

-

userdata is too large

-

flavor's memory is too small for requested image(min_ram)

-

flavor's disk is too small for requested image(min_disk)

-

image is not active

-

not found a specified network id

-

not found a specified image id

-

not found a specified port id

-

not found a specified flavor id

-

source_type is 'blank' and volume_id is not None

-

source_type is not 'blank' and volume_id is None

-

boot_index is not be converted to an integer

-

block_device_mapping and block_device_mapping_v2 is both exist in body

-

if source type is volume,snapshot,image there is not found uuid entity in body

-

if source type is volume, uuid isn't a volume id

-

if source type is snapshot, uuid isn't a snapshot id

-

if source type is image, uuid isn't a image id

-

specified swap size is over the limit swap size of flavor for VM

-

specified ephemeral size is over the limit swap size of flavor for VM

-

multiple swap devices are specified in block_device_mapping_v2

-

order of bootindex incorrect on multiple devices of block_device_mapping_v2

-

If attach a volume in the BDM or BDMv2, Volume must be the same availability zone with the VM.

401

unauthorized

403

TooManyInstances

-

Maximum number of ports exceeded

-

Maximum number of metadata items exceeded

-

min_count > instance limit of quota.

404

not found a specified project

409

port is in-use

500

glance-api process is stopped

-

glance-registry process is stopped

-

cinder-api process is stopped

-

neutron server process is stopped

HTTP Response Body

Format

{
    "server": {
        "OS-DCF:diskConfig": "<disk_config>",
        "adminPass": "<admin_pass>",
        "id": "<instance_id>",
        "links": [
            {
                "href": "<instance_url>",
                "rel": "self"
            },
            {
                "href": "<bookmark_url>",
                "rel": "bookmark"
            }
        ],
        "security_groups": [
            {
                "name": "<security_group_name>"
            }
        ]
    }
}

Response Parameter

Response Parameters

item

format

description

disk_config

String (AUTO or MANUAL)

Auto: a single partition which is expanded to the size of the flavor selected

admin_pass

String

adminstrator password

instance_id

UUID

instance id

instance_url

URL

instance url

bookmark_url

URL

bookmark url

security_group_name

String(1-255 characters)

securiy group name of instance

Sample API Request and Response

Sample API Request

Request URI

https://example.com/v2/{project_id}/servers

Request Header

Accept-Encoding: gzip, deflate, compress (optional)
Accept: application/json
X-Auth-Token: ajk3adjiown02
Content-Type: application/json

Request Body

{
    "server": {
        "OS-DCF:diskConfig": "<disk_config>",
        "flavorRef": "<flavor_id>",
        "imageRef": "<image_id>",
        "max_count": <min_count>,
        "min_count": <max_count>,
        "name": "<instance_name>",
        "availability_zone": "<availability_zone>",
        "config_drive": "<config_drive>",
        "key_name": "<key_name>",
        "user_data": "<user_data>",
        "block_device_mapping": [
             {
                "volume_id": "<volume_id>",
                "delete_on_termination": <delete_flag>,
                "device_name": "<device_name>"
            },
            <<repeat>>
        ],
        "block_device_mapping_v2": [
            {
                "no_device": "<no_device(bdm_v2)>",
                "device_name": "<device_name(bdm_v2)>",
                "source_type": "<source_type(bdm_v2)>",
                "destination_type": "<destination_type(bdm_v2)>",
                "guest_format": "<guest_format(bdm_v2)>",
                "uuid": "<uuid(bdm_v2)>",
                "boot_index": "<boot_index(bdm_v2)>",
                "volume_size": <volume_size(bdm_v2)>,
                "device_type": "<device_type(bdm_v2)>",
                "disk_bus": "<disk_bus(bdm_v2)>",
                "delete_on_termination": <delete_on_termination(bdm_v2)>
            },
            <<repeat>>
        ],
        "metadata": {
               "<metadata_key>": "<metadata_value>",
                <<repeat>>
         },
        "networks": [
           {
              "uuid": "<network_id>",
              "fixed_ip": "<fixed_ip>"
            },
            {
               "port": "<port_id>"
            }
            <<repeat>>
         ],
    }
}

Sample API Response

Response Header

HTTP/1.1 202 OK
  • <response_code>: see "HTTP Responses" section

  • <message>: message based on the response code

    • skip auto insert field such as "X-Compute-Request-Id" and "Content-Length", "Date"

Response Body

{
    "server": {
        "OS-DCF:diskConfig": "<disk_config>",
        "adminPass": "<admin_pass>",
        "id": "<instance_id>",
        "links": [
            {
                "href": "<instance_url>",
                "rel": "self"
            },
            {
                "href": "<bookmark_url>",
                "rel": "bookmark"
            }
        ],
        "security_groups": [
            {
                "name": "<security_group_name>"
            }
        ]
    }
}

Execution Example 1. create server

HTTP Request

POST /v2/fd57c99ad0d7491fa496a3ac9a44eb7c/servers HTTP/1.1
User-Agent: curl/7.35.0
Host: 192.168.150.51:8774
Accept-Encoding: gzip, deflate, compress
Accept: application/json
X-Auth-Token: 734732012f404526926dc7e1d9e846ff
Content-Type: application/json
Content-Length: 130

{"server": {"flavorRef": "1CPU-4GB","name": "Testvm1","imageRef": "a3bf7a3d-f842-4bb7-b005-cbe8e42fc843"}}

HTTP Response

HTTP/1.1 202 Accepted
Location: http://192.168.150.51:8774/v2/fd57c99ad0d7491fa496a3ac9a44eb7c/servers/74f4aba6-64df-4004-b886-a4fb3461cf73
Content-Type: application/json
Content-Length: 444
X-Compute-Request-Id: req-24aaea55-849f-482b-9870-3464a80153db
Date: Sun, 21 Sep 2014 05:37:45 GMT

{"server": {"security_groups": [{"name": "default"}], "OS-DCF:diskConfig": "MANUAL", "id": "74f4aba6-64df-4004-b886-a4fb3461cf73", "links": [{"href": "http://192.168.150.51:8774/v2/fd57c99ad0d7491fa496a3ac9a44eb7c/servers/74f4aba6-64df-4004-b886-a4fb3461cf73", "rel": "self"}, {"href": "http://192.168.150.51:8774/fd57c99ad0d7491fa496a3ac9a44eb7c/servers/74f4aba6-64df-4004-b886-a4fb3461cf73", "rel": "bookmark"}], "adminPass": "vffeEYsLvR5H"}}

Execution Example 2. create server with VMHA disabled

HTTP Request

POST /v2/fd57c99ad0d7491fa496a3ac9a44eb7c/servers HTTP/1.1
User-Agent: curl/7.35.0
Host: 192.168.150.51:8774
Accept-Encoding: gzip, deflate, compress
Accept: application/json
X-Auth-Token: 734732012f404526926dc7e1d9e846ff
Content-Type: application/json
Content-Length: 130

{"server": {"flavorRef": "1CPU-4GB","name": "Testvm1","imageRef": "a3bf7a3d-f842-4bb7-b005-cbe8e42fc843", "metadata": {"HA_Enabled": "false" }}}

HTTP Response

HTTP/1.1 202 Accepted
Location: http://192.168.150.51:8774/v2/fd57c99ad0d7491fa496a3ac9a44eb7c/servers/18a560f3-5572-4b1e-88d0-0db23939eed0
Content-Type: application/json
Content-Length: 444
X-Compute-Request-Id: req-24aaea55-849f-482b-9870-3464a80153db
Date: Sun, 21 Sep 2014 05:37:45 GMT

{"server": {"security_groups": [{"name": "default"}], "OS-DCF:diskConfig": "MANUAL", "id": "18a560f3-5572-4b1e-88d0-0db23939eed0", "links": [{"href": "http://192.168.150.51:8774/v2/fd57c99ad0d7491fa496a3ac9a44eb7c/servers/18a560f3-5572-4b1e-88d0-0db23939eed0", "rel": "self"}, {"href": "http://192.168.150.51:8774/fd57c99ad0d7491fa496a3ac9a44eb7c/servers/18a560f3-5572-4b1e-88d0-0db23939eed0", "rel": "bookmark"}], "adminPass": "B8L9FUyxxfsv"}}

Error Execution Example

HTTP Request

POST /v2/b17a6492bfa54441910e15f07c983384/servers HTTP/1.1
User-Agent: curl/7.35.0
Host: 192.168.56.250:8774
X-Auth-Token: 5565d8f69d9a43b698aa30f30ebc681b
Content-type: application/json
Accept: application/json
Content-Length: 130

HTTP Response

HTTP/1.1 400 Bad Request
Content-Length: 72
Content-Type: application/json; charset=UTF-8
X-Compute-Request-Id: req-a66626f9-0287-4eb1-8e14-46467802f129
Date: Tue, 06 Oct 2015 07:41:51 GMT

{"badRequest": {"message": "Can not find requested image", "code": 400}}