云主机
列举云主机
功能介绍
列举所有云主机和云主机相关的属性。
前提条件
云平台服务正常。
URI
GET /servers
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
access_ip_v4 | string | 否 | 按照云主机的IPv4地址过滤服务器列表结果。 |
access_ip_v6 | string | 否 | 按照云主机的IPv6地址过滤服务器列表结果。 |
availability_zone | string | 否 | 可用区。 |
created_at | string | 否 | 云主机创建时间。 |
description | string | 否 | 云主机描述信息。 |
flavor | string | 否 | 规格uuid。 |
host | string | 否 | 计算节点主机名。 |
hostname | string | 否 | 云主机的主机名。 |
key_name | string | 否 | 秘钥对名字。 |
launched_at | string | 否 | 云主机的启动时间。 |
power_state | integer | 否 | 云主机电源状态:
|
progress | integer | 否 | 云主机的进度条。 |
status | string | 否 | 云主机的状态。 |
task_state | string | 否 | 云主机的任务状态。 |
vm_state | string | 否 | 虚拟机的状态。 |
changes-before | string | 否 | 按服务器上次更改时的日期和时间戳过滤响应。 返回在指定日期和时间戳之前或等于指定日期和时间戳之前更改的那些服务器。 |
limit | integer | 否 | 查询的最大个数限制。 |
marker | string | 否 | 最后一项的ID。 |
sort_key | string | 否 | 按照云主机属性排序。 |
sort_dir | string | 否 | 排序方向。 |
changes-since | string | 否 | 根据云主机最后更改时间戳过滤查询结果。 |
image | string | 否 | 根据镜像的uuid过滤查询。 |
flavor | string | 否 | 根据规格的uuid过滤查询。 |
name | string | 否 | 可根据云主机的名字过滤查询。 |
status | string | 否 | 根据云主机的状态过滤查询。 |
ip | string | 否 | 根据IPv4地址过滤查询。 |
ip6 | string | 否 | 根据IPv6地址过滤查询。最小支持微版本2.5。 |
reservation_id | string | 否 | 服务器多次创建调用返回的保留id。 |
all_tenants | integer | 否 | 是否查询所有项目的云主机。 |
deleted | boolean | 否 | 是否查询已经删除的云主机。 |
注:建议您在请求头中设置如下内容以使用推荐版本的API:”X-OpenStack-Nova-API-Version: compute 2.25”。
响应消息
参数 | 参数类型 | 描述 |
---|---|---|
servers | array | 云主机列表对象。 |
id | string | 云主机的UUID。 |
name | string | 云主机的名字。 |
links | array | 云主机资源链接。 |
响应示例
{
"servers": [
{
"id": "2e136db7-b4a4-4815-8a00-25d9bfe59617",
"status": "UNKNOWN",
"links": [
{
"href": "http://openstack.example.com/v2.1/6f70656e737461636b20342065766572/servers/2e136db7-b4a4-4815-8a00-25d9bfe59617",
"rel": "self"
},
{
"href": "http://openstack.example.com/6f70656e737461636b20342065766572/servers/2e136db7-b4a4-4815-8a00-25d9bfe59617",
"rel": "bookmark"
}
]
}
]
}
正常响应代码
200
列举云主机列表详情
功能介绍
列举云主机列表详情。
前提条件
云平台服务正常。
URI
GET /servers/detail
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
access_ip_v4 | string | 否 | 按照云主机的IPv4地址过滤服务器列表结果。 |
access_ip_v6 | string | 否 | 按照云主机的IPv6地址过滤服务器列表结果。 |
availability_zone | string | 否 | 可用区。 |
created_at | string | 否 | 云主机创建时间。 |
description | string | 否 | 云主机描述信息。 |
flavor | string | 否 | 规格uuid。 |
host | string | 否 | 计算节点主机名。 |
hostname | string | 否 | 云主机的主机名。 |
key_name | string | 否 | 秘钥对名字。 |
launched_at | string | 否 | 云主机的启动时间。 |
power_state | integer | 否 | 云主机电源状态:
|
progress | integer | 否 | 云主机的进度条。 |
status | string | 否 | 云主机的状态。 |
task_state | string | 否 | 云主机的任务状态。 |
vm_state | string | 否 | 虚拟机的状态。 |
changes-before | string | 否 | 按服务器上次更改时的日期和时间戳过滤响应。 返回在指定日期和时间戳之前或等于指定日期和时间戳之前更改的那些服务器。 |
limit | integer | 否 | 查询的最大个数限制。 |
marker | string | 否 | 最后一项的ID。 |
sort_key | string | 否 | 按照云主机属性排序。 |
sort_dir | string | 否 | 排序方向。 |
changes-since | string | 否 | 根据云主机最后更改时间戳过滤查询结果。 |
image | string | 否 | 根据镜像的uuid过滤查询。 |
flavor | string | 否 | 根据规格的uuid过滤查询。 |
name | string | 否 | 可根据云主机的名字过滤查询。 |
status | string | 否 | 根据云主机的状态过滤查询。 |
ip | string | 否 | 根据IPv4地址过滤查询。 |
ip6 | string | 否 | 根据IPv6地址过滤查询。最小支持微版本2.5。 |
reservation_id | string | 否 | 服务器多次创建调用返回的保留id。 |
all_tenants | integer | 否 | 是否查询所有项目的云主机。 |
deleted | boolean | 否 | 是否查询已经删除的云主机。 |
注:建议您在请求头中设置如下内容以使用推荐版本的API:”X-OpenStack-Nova-API-Version: compute 2.25”。
响应消息
参数 | 参数类型 | 描述 |
---|---|---|
server | object | 云主机对象 |
accessIPv4 | string | 用于访问此服务器的IPv4地址 |
accessIPv6 | string | 用于访问此服务器的IPv6地址 |
addresses | object | 云主机网络地址 |
config_drive | string | 是否启用config_drive |
created | string | 云主机创建时间 |
flavor | object | 云主机规格 |
hostId | string | 主机uuid |
id | string | 云主机uuid |
image | object | 云主机镜像信息 |
key_name | string | 秘钥对名称 |
metadata | object | 云主机元数据 |
name | string | 云主机名称 |
OS-DCF:diskConfig | string | 在创建、重新构建或调整服务器大小时,控制API如何对磁盘进行分区。服务器从创建它的映像继承OS-DCF:diskConfig值,映像从创建它的服务器继承OS-DCF:diskConfig值。若要重写继承的设置,可以在服务器创建、重新生成或调整请求的请求主体中包含此属性。如果镜像的OS-DCF:diskConfig值为MANUAL,则不能从该镜像创建服务器,并将其OS-DCF:diskConfig值设置为AUTO。有效值为:
|
OS-EXT-AZ:availability_zone | string | 可用区名称 |
OS-EXT-SRV-ATTR:host | string | 云主机运行的节点 |
OS-EXT-SRV-ATTR:hostname | string | openstack创建的云主机名称 |
OS-EXT-SRV-ATTR:hypervisor_hostname | string | 计算节点主机名 |
OS-EXT-SRV-ATTR:instance_name | string | 云主机名称,对应libvirt名称 |
OS-EXT-SRV-ATTR:kernel_id | string | 内核镜像id |
OS-EXT-SRV-ATTR:launch_index | integer | 批量创建云主机时索引 |
OS-EXT-SRV-ATTR:ramdisk_id | string | 内存镜像Uuid |
OS-EXT-SRV-ATTR:reservation_id | string | 服务器多次创建调用返回的保留id |
OS-EXT-SRV-ATTR:root_device_name | string | 系统盘名称 |
OS-EXT-SRV-ATTR:user_data | string | 启动时使用的配置信息或脚本。必须是Base64编码的。限制为65535字节 |
OS-EXT-SRV-ATTR:power_state | integer | 云主机电源状态:
|
OS-EXT-SRV-ATTR:task_state | string | 云主机任务状态 |
OS-EXT-SRV-ATTR:vm_state | string | 云主机状态 |
os-extended-volumes:volumes_attached | array | 挂载的云硬盘 |
OS-SRV-USG:launched_at | string | 云主机launched时间 |
OS-SRV-USG:terminated_at | string | 云主机删除时间 |
status | string | 云主机状态 |
tenant_id | string | 租户id |
updated | string | 更新时间 |
user_id | string | 用户id |
progress | integer | 任务的进度 |
security_groups | array | 安全组 |
locked | boolean | 是否锁定 |
host_status | string | 主机状态:
|
description | string | 云主机描述信息 |
tags | string | 标签 |
trusted_image_certificates | array | 受信任证书ID |
estimated_deleted | string | 预计删除时间 |
fault | body | 只在云主机处于ERROR或者DELETED状态时才有的错误信息 |
deleted | string | 删除时间 |
响应示例
{
"servers": [{
"id": "8e609d42-fdc3-453c-ab85-f323c78f3918",
"name": "instance-bgzz",
"status": "ERROR",
"tenant_id": "c1869da142e94aa99ae1a0391360f99a",
"user_id": "e36a6c6aafcb4581bbb12196e393242d",
"metadata": {},
"hostId": "",
"image": "",
"flavor": {
"id": "2",
"vcpus": 1,
"ram": 1024,
"disk": 0,
"ephemeral": 0,
"swap": 0,
"original_name": "1C-1G",
"extra_specs": {}
},
"created": "2022-08-23T11:35:12Z",
"updated": "2022-08-23T11:37:44Z",
"deleted": "",
"estimated_deleted": "",
"addresses": {},
"accessIPv4": "",
"accessIPv6": "",
"links": [{
"rel": "self",
"href": "http://nova-api.openstack.svc.cluster.local:8774/v2.1/a335034a25e942c9b4dc9901b1604898/servers/8e609d42-fdc3-453c-ab85-f323c78f3918"
}, {
"rel": "bookmark",
"href": "http://nova-api.openstack.svc.cluster.local:8774/a335034a25e942c9b4dc9901b1604898/servers/8e609d42-fdc3-453c-ab85-f323c78f3918"
}],
"OS-DCF:diskConfig": "AUTO",
"fault": {
"code": 500,
"created": "2022-08-23T11:37:45Z",
"message": "Exceeded maximum number of retries. Exceeded max scheduling attempts 3 for instance 8e609d42-fdc3-453c-ab85-f323c78f3918. Last exception: Failed to locate firmware descriptor files",
"details": "Traceback (most recent call last):\n File \"/usr/local/lib/python3.6/site-packages/nova/conductor/manager.py\", line 652, in build_instances\n filter_properties, instances[0].uuid)\n File \"/usr/local/lib/python3.6/site-packages/nova/scheduler/utils.py\", line 976, in populate_retry\n raise exception.MaxRetriesExceeded(reason=msg)\nnova.exception.MaxRetriesExceeded: Exceeded maximum number of retries. Exceeded max scheduling attempts 3 for instance 8e609d42-fdc3-453c-ab85-f323c78f3918. Last exception: Failed to locate firmware descriptor files\n"
},
"OS-EXT-AZ:availability_zone": "",
"config_drive": "",
"key_name": null,
"OS-SRV-USG:launched_at": null,
"OS-SRV-USG:terminated_at": null,
"OS-EXT-SRV-ATTR:host": null,
"OS-EXT-SRV-ATTR:instance_name": "instance-0000007a",
"OS-EXT-SRV-ATTR:hypervisor_hostname": null,
"OS-EXT-SRV-ATTR:reservation_id": "r-oxaqe5rb",
"OS-EXT-SRV-ATTR:launch_index": 0,
"OS-EXT-SRV-ATTR:hostname": "instance-bgzz",
"OS-EXT-SRV-ATTR:kernel_id": "",
"OS-EXT-SRV-ATTR:ramdisk_id": "",
"OS-EXT-SRV-ATTR:root_device_name": "/dev/vda",
"OS-EXT-SRV-ATTR:user_data": "Q29udGVudC1UeXBlOiBtdWx0aXBhcnQvbWl4ZWQ7IGJvdW5kYXJ5PSI9PT09PT09PT09PT09PT03ODUyMjg5NjQ5Mjg5Nzc2NzU2PT0iCk1JTUUtVmVyc2lvbjogMS4wCgotLT09PT09PT09PT09PT09PTc4NTIyODk2NDkyODk3NzY3NTY9PQpDb250ZW50LVR5cGU6IHRleHQvcGxhaW47IGNoYXJzZXQ9InVzLWFzY2lpIgpNSU1FLVZlcnNpb246IDEuMApDb250ZW50LVRyYW5zZmVyLUVuY29kaW5nOiA3Yml0CgojY2xvdWQtY29uZmlnCmNocGFzc3dkOgogIGxpc3Q6IHwKICAgIHJvb3Q6R2FvemhhbzE5OTUwMQogIGV4cGlyZTogZmFsc2UKLS09PT09PT09PT09PT09PT03ODUyMjg5NjQ5Mjg5Nzc2NzU2PT0KQ29udGVudC1UeXBlOiB0ZXh0L3BsYWluOyBjaGFyc2V0PSJ1cy1hc2NpaSIKTUlNRS1WZXJzaW9uOiAxLjAKQ29udGVudC1UcmFuc2Zlci1FbmNvZGluZzogN2JpdAoKI2Nsb3VkLWNvbmZpZwpjaHBhc3N3ZDoKICBsaXN0OiB8CiAgICByb290Okdhb3poYW8xOTk1MDEKICBleHBpcmU6IGZhbHNlCi0tPT09PT09PT09PT09PT09Nzg1MjI4OTY0OTI4OTc3Njc1Nj09CkNvbnRlbnQtVHlwZTogdGV4dC9wbGFpbjsgY2hhcnNldD0idXMtYXNjaWkiCk1JTUUtVmVyc2lvbjogMS4wCkNvbnRlbnQtVHJhbnNmZXItRW5jb2Rpbmc6IDdiaXQKCiNjbG91ZC1jb25maWcKY2hwYXNzd2Q6CiAgbGlzdDogfAogICAgcm9vdDpHYW96aGFvMTk5NTAxCiAgZXhwaXJlOiBmYWxzZQotLT09PT09PT09PT09PT09PTc4NTIyODk2NDkyODk3NzY3NTY9PS0tCg==",
"OS-EXT-STS:task_state": null,
"OS-EXT-STS:vm_state": "error",
"OS-EXT-STS:power_state": 0,
"os-extended-volumes:volumes_attached": [{
"id": "9d5e20bf-8bf3-4441-8fc5-b0bd3746a613",
"delete_on_termination": true
}],
"locked": false,
"description": null,
"tags": [],
"trusted_image_certificates": null,
"host_status": ""
}
]
}
正常响应代码
200
云主机详情
功能介绍
显示云主机详细信息。
前提条件
云平台服务正常。
URI
GET /servers/{server_id}
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 要查找的云主机uuid |
注:建议您在请求头中设置如下内容以使用推荐版本的API:”X-OpenStack-Nova-API-Version: 2.25”。
响应消息
参数 | 参数类型 | 描述 |
---|---|---|
server | object | 云主机对象 |
accessIPv4 | string | 用于访问此服务器的IPv4地址 |
accessIPv6 | string | 用于访问此服务器的IPv6地址 |
addresses | object | 云主机网络地址 |
config_drive | string | 是否启用config_drive |
created | string | 云主机创建时间 |
flavor | object | 云主机规格 |
hostId | string | 主机uuid |
id | string | 云主机uuid |
image | object | 云主机镜像信息 |
key_name | string | 秘钥对名称 |
metadata | object | 云主机元数据 |
name | string | 云主机名称 |
OS-DCF:diskConfig | string | 在创建、重新构建或调整服务器大小时,控制API如何对磁盘进行分区。服务器从创建它的映像继承OS-DCF:diskConfig值,映像从创建它的服务器继承OS-DCF:diskConfig值。若要重写继承的设置,可以在服务器创建、重新生成或调整请求的请求主体中包含此属性。如果镜像的OS-DCF:diskConfig值为MANUAL,则不能从该镜像创建服务器,并将其OS-DCF:diskConfig值设置为AUTO。有效值为:
|
OS-EXT-AZ:availability_zone | string | 可用区名称 |
OS-EXT-SRV-ATTR:host | string | 云主机运行的节点 |
OS-EXT-SRV-ATTR:hostname | string | openstack创建的云主机名称 |
OS-EXT-SRV-ATTR:hypervisor_hostname | string | 计算节点主机名 |
OS-EXT-SRV-ATTR:instance_name | string | 云主机名称,对应libvirt名称 |
OS-EXT-SRV-ATTR:kernel_id | string | 内核镜像id |
OS-EXT-SRV-ATTR:launch_index | integer | 批量创建云主机时索引 |
OS-EXT-SRV-ATTR:ramdisk_id | string | 内存镜像Uuid |
OS-EXT-SRV-ATTR:reservation_id | string | 服务器多次创建调用返回的保留id |
OS-EXT-SRV-ATTR:root_device_name | string | 系统盘名称 |
OS-EXT-SRV-ATTR:user_data | string | 启动时使用的配置信息或脚本。必须是Base64编码的。限制为65535字节 |
OS-EXT-SRV-ATTR:power_state | integer | 云主机电源状态:
|
OS-EXT-SRV-ATTR:task_state | string | 云主机任务状态 |
OS-EXT-SRV-ATTR:vm_state | string | 云主机状态 |
os-extended-volumes:volumes_attached | array | 挂载的云硬盘 |
OS-SRV-USG:launched_at | string | 云主机launched时间 |
OS-SRV-USG:terminated_at | string | 云主机删除时间 |
status | string | 云主机状态 |
tenant_id | string | 租户id |
updated | string | 更新时间 |
user_id | string | 用户id |
progress | integer | 任务的进度 |
security_groups | array | 安全组 |
locked | boolean | 是否锁定 |
host_status | string | 主机状态:
|
description | string | 云主机描述信息 |
tags | string | 标签 |
trusted_image_certificates | array | 受信任证书ID |
estimated_deleted | string | 预计删除时间 |
share_net network | string | 网络ip |
addresses_labels_mac | string | 网卡mac id 列表 |
fault | body | 只在云主机处于ERROR或者DELETED状态时才有的错误信息 |
响应示例
{
"server": {
"id": "362e672a-8510-4164-af2e-9dbf5c1de836",
"name": "instance-REK4t4-9",
"status": "ACTIVE",
"tenant_id": "19eedeacd8524fa196a1aa8d4ee5d9d7",
"user_id": "f7c185b91b4d46ff9883f955d88a6f3c",
"metadata": {},
"hostId": "bbb18782dac7909c9c68e42014e824351369f398860e1db110f2bb1e",
"image": "",
"flavor": {
"id": "1",
"vcpus": 1,
"ram": 512,
"disk": 0,
"ephemeral": 0,
"swap": 0,
"original_name": "1C-0.5G",
"extra_specs": {}
},
"created": "2022-04-27T13:03:50Z",
"updated": "2022-04-27T13:03:56Z",
"deleted": "",
"estimated_deleted": "",
"addresses": {
"share_net": [{
"version": 4,
"addr": "192.168.111.202",
"OS-EXT-IPS:type": "fixed",
"OS-EXT-IPS-MAC:mac_addr": "fa:16:3e:e7:ce:0b"
}]
},
"accessIPv4": "",
"accessIPv6": "",
"links": [{
"rel": "self",
"href": "http://nova-api.openstack.svc.cluster.local:8774/v2.1/7225700f836440b98e68159b32b1a067/servers/362e672a-8510-4164-af2e-9dbf5c1de836"
}, {
"rel": "bookmark",
"href": "http://nova-api.openstack.svc.cluster.local:8774/7225700f836440b98e68159b32b1a067/servers/362e672a-8510-4164-af2e-9dbf5c1de836"
}],
"OS-DCF:diskConfig": "AUTO",
"addresses_labels_mac": ["fa:16:3e:e7:ce:0b"],
"progress": 0,
"OS-EXT-AZ:availability_zone": "default-az",
"config_drive": "",
"key_name": null,
"OS-SRV-USG:launched_at": "2022-04-27T13:03:56.000000",
"OS-SRV-USG:terminated_at": null,
"security_groups": [{
"name": "lbq"
}],
"OS-EXT-SRV-ATTR:host": "node-2.domain.tld",
"OS-EXT-SRV-ATTR:instance_name": "instance-00000136",
"OS-EXT-SRV-ATTR:hypervisor_hostname": "node-2.domain.tld",
"OS-EXT-SRV-ATTR:reservation_id": "r-ckzb7q50",
"OS-EXT-SRV-ATTR:launch_index": 0,
"OS-EXT-SRV-ATTR:hostname": "instance-rek4t4-9",
"OS-EXT-SRV-ATTR:kernel_id": "",
"OS-EXT-SRV-ATTR:ramdisk_id": "",
"OS-EXT-SRV-ATTR:root_device_name": "/dev/vda",
"OS-EXT-SRV-ATTR:user_data": "Q29udGVudC1UeXBlOiB0ZXh0L3BsYWluOyBjaGFyc2V0PSJ1cy1hc2NpaSIKTUlNRS1WZXJzaW9uOiAxLjAKQ29udGVudC1UcmFuc2Zlci1FbmNvZGluZzogN2JpdAoKI2Nsb3VkLWNvbmZpZwpjaHBhc3N3ZDoKICBsaXN0OiB8CiAgICByb290OnRlc3RAcGFzc3cwcmQKICBleHBpcmU6IGZhbHNl",
"OS-EXT-STS:task_state": null,
"OS-EXT-STS:vm_state": "active",
"OS-EXT-STS:power_state": 1,
"os-extended-volumes:volumes_attached": [{
"id": "f3846166-b7dd-4cbc-be1e-ceb3576966ad",
"delete_on_termination": true
}],
"host_status": "UP",
"locked": false,
"description": null,
"tags": [],
"trusted_image_certificates": null
}
}
正常响应代码
200
异常响应代码
401 403 404
创建云主机
功能介绍
创建一个云主机。
前提条件(可选)
- 用户必须有足够的云主机配额才能创建所请求的云主机数量。
- 与Image服务的连接是有效的。
接口约束(可选)
- 此操作的进度取决于请求镜像的位置,网络I/O,主机负载,选定的flavor和其他因素。
- 要检查请求的进度,请执行GET / servers / {id}请求。 此调用返回一个进度属性,该属性是从0到100的百分比值。
- Location标头将完整的URI返回给新创建的云主机,并且可以作为云主机表示中的“self”和“bookmark”链接。
- 创建云主机时,响应仅显示云主机ID,其链接和管理员密码。 您可以通过云主机上的后续GET请求获取其他属性。
- 在创建请求正文中包含block-device-mapping-v2参数,以便从卷引导云主机。
- 在创建请求正文中包含key_name参数,以便在创建它时向云主机添加密钥对。 要创建一个密钥对,请创建一个create keypair http://developer.openstack.org/api-ref/compute/#create-or-import-keypair 请求。
故障排除
- 如果云主机状态保持“BUILDING”或显示另一个错误状态,请求失败。 确保您满足前提条件,然后调查计算节点。
- 在OpenStack Compute管理的计算节点中不创建云主机。
- 计算节点需要足够的可用资源来匹配云主机创建请求的资源。
- 确保调度程序选择过滤器可以使用与过滤器的选择条件匹配的可用计算节点来满足请求。
异步后置条件
- 具有正确的权限,您可以通过API调用将云主机状态看作“ACTIVE”。
- 通过正确的访问,您可以看到OpenStack Compute管理的计算节点中创建的云主机。
注意
如果想在创建的时候使用共享云硬盘,需要微版本号大于等于2.60
URI
POST /servers
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server | object | 是 | 要创建云主机所需的信息。 |
flavorRef | string | 是 | 要创建云主机所使用的规格。 |
name | string | 是 | 云主机名称。 |
networks | array | 是 | 网络对象列表。 为租户定义了多个网络时的必需参数。 如果不指定networks参数,则云主机将连接到为当前租户创建的唯一网络。 或者,您可以在云主机上创建一个或多个NIC。 要为云主机实例提供网络的NIC,请在网络对象的uuid属性中指定网络的UUID。 要为云主机实例提供一个已存在端口的NIC,请在网络对象的port属性中指定port-id。 |
networks.uuid | string | 否 | 要为云主机实例提供网络网卡,请在网络对象的UUID属性中指定网络的UUID。如果您省略了端口属性,则需要。从microversion 2.37开始,该值严格强制为UUID格式。 |
networks.port | string | 否 | 要为云主机实例提供一个已存在端口的网卡,请在网络对象的port属性中指定port-id。 端口状态必须为DOWN。 如果省略uuid属性,则为必需。 所请求的安全组不应用于预先存在的端口。 |
networks.subnet_id | array | 否 | 指定子网为云主机设置IPv4/IPv6双栈 |
networks.fixed_ip | string | 否 | 网卡的IPv4地址。适用于neutron或nova-networks网络。 |
networks.tag | string | 否 | 可应用于网络接口的设备角色标签。 |
accessIPv4 | string | 否 | 用于访问此服务器的IPv4地址。 |
accessIPv6 | string | 否 | 用于访问此服务器的IPv6地址。 |
adminPass | string | 否 | 云主机的管理密码。 如果省略此参数,则该操作将生成一个新密码。 |
availability_zone | string | 否 | 用于创建云主机的可用区域。在提供资源时,您可以指定从哪个可用分区构建实例。 |
block_device_mapping_v2 | array | 否 | 云主机实例的卷信息。 |
block_device_mapping_v2.boot_index | integer | 是 | 定义虚拟化层尝试从存储引导系统时尝试设备的顺序。给每个设备一个从0开始的唯一引导索引。如果要禁止设备启动,可以将启动索引设置为负值或使用默认的启动索引值None。最简单的方法是将启动设备的启动索引设置为0,其他设备使用默认的启动索引值None。一些虚拟化层可能不支持从多个设备启动;这些虚拟化层只考虑引导索引为0的设备。一些虚拟化层支持从多个设备启动,但只有在设备类型不同的情况下才支持。例如,磁盘和CD-ROM。 |
block_device_mapping_v2.delete_on_termination | boolean | 否 | 如果要在云主机被销毁时删除对应的存储设备,请指定true。否则为false。默认值:false。 |
block_device_mapping_v2.destination_type | string | 否 | 定义卷从哪来的。有效值:
|
block_device_mapping_v2.device_name | string | 否 | 要用于引导云主机的卷的设备路径。注意,从12.0.0 Liberty版本开始,Nova libvirt驱动程序不再使用用户提供的设备名。这与请求中没有提供设备名参数是相同的行为。 |
block_device_mapping_v2.device_type | string | 否 | 设备类型。例如:disk, cdrom。 |
block_device_mapping_v2.disk_bus | string | 否 | 磁盘总线类型,一些虚拟化层(目前仅libvirt)支持指定此参数。例如,disk_bus的值可以是:fdc、ide、sata、scsi、usb、virtio、xen、lxc和uml。对每种总线类型的支持取决于虚拟化驱动程序和底层管理程序。 |
block_device_mapping_v2.guest_format | string | 否 | 指定客户服务器磁盘的文件系统格式,如ext2、ext3、ext4、xfs或swap。交换块设备映射有以下限制:
|
block_device_mapping_v2.no_device | boolean | 否 | 当值为True时表示无设备。 |
block_device_mapping_v2.source_type | string | 否 | 块设备的源类型。 有效值为:
|
block_device_mapping_v2.uuid | string | 否 | 这是源资源的uuid。 uuid基于source_type指向不同的资源。 例如,如果source_type是image,则基于从图像服务检索的指定图像创建块设备。 同样,如果source_type是快照,则uuid引用块存储服务中的卷快照。 如果source_type是volume,则uuid引用块存储服务中的卷。 |
block_device_mapping_v2.volume_size | integer | 否 | 卷的大小(以GiB为单位)。 这是范围从1到2147483647的整数值,可以整数和字符串的形式请求。 |
block_device_mapping_v2.tag | string | 否 | 可以应用于块设备的设备角色标签。 具有以此方式标记的设备的服务器的来宾OS可以从元数据API和配置驱动器(如果已启用)访问有关标记的设备的硬件元数据。 |
block_device_mapping_v2.volume_type | string | 否 | 设备的volume_type。这可用于指定计算服务将创建并连接到服务器的卷的类型。如果未指定,块存储服务将提供默认卷类型。有关详细信息,请参阅块存储卷类型API。 |
imageRef | string | 否 | 用于创建云主机实例的镜像的UUID。在从卷引导的情况下,这不是必需的。在所有其他情况下,它都是必需的,并且必须是有效的UUID,否则API将返回400。 |
key_name | string | 否 | 密钥对名称。 |
metadata | object | 否 | 元数据键值对。metadata key和value的最大大小都是255字节,可设置key:
|
OS-DCF:diskConfig | string | 否 | 在创建、重新构建或调整服务器大小时,控制API如何对磁盘进行分区。服务器从创建它的映像继承OS-DCF:diskConfig值,映像从创建它的服务器继承OS-DCF:diskConfig值。若要重写继承的设置,可以在服务器创建、重新生成或调整请求的请求主体中包含此属性。如果镜像的OS-DCF:diskConfig值为MANUAL,则不能从该镜像创建服务器,并将其OS-DCF:diskConfig值设置为AUTO。有效值为:
|
personality | array | 否 | 启动时注入到云主机的文件路径和内容(仅为文本)。 文件路径数据的最大长度为255字节。 最大限制是在已解码而不是已编码的数据中允许的字节数。 |
security_groups | array | 否 | 一个或多个安全组。在“名称”属性中指定安全组的名称。如果忽略此属性,API将在默认安全组中创建服务器。请求的安全组没有应用到已存在的端口。 |
user_data | string | 否 | 启动时使用的配置信息或脚本。必须是Base64编码的。限制为65535字节。 |
description | string | 否 | 服务器的自由形式描述。长度限制为255个字符。在microversion 2.19之前,这被设置为服务器名。2.19新版功能 |
tags | string | 否 | 标签列表。2.52新版功能,标签有以下限制:
|
host | string | 否 | 创建云主机的物理主机。 |
hypervisor_hostname | string | 否 | 要在其上创建服务器的管理程序的主机名。如果没有找到具有给定主机名的虚拟机监控程序,API将返回400。缺省情况下,只能由管理员指定。 |
注:建议您在请求头中设置如下内容以使用推荐版本的API:”X-OpenStack-Nova-API-Version: 2.67”。
请求示例
示例一:创建云主机
{
"server" : {
"accessIPv4": "1.2.3.4",
"accessIPv6": "80fe::",
"name" : "new-server-test",
"imageRef" : "70a599e0-31e7-49b7-b260-868f441e862b",
"flavorRef" : "1",
"availability_zone": "us-west",
"OS-DCF:diskConfig": "AUTO",
"metadata" : {
"My Server Name" : "Apache1"
},
"personality": [
{
"path": "/etc/banner.txt",
"contents": "fake_contents"
}
],
"security_groups": [
{
"name": "default"
}
],
"user_data" : "fake_user_data"
},
}
示例二:创建自动网络云主机(v2.37)
{
"server": {
"name": "auto-allocate-network",
"imageRef": "70a599e0-31e7-49b7-b260-868f441e862b",
"flavorRef": "http://openstack.example.com/flavors/1",
"networks": "auto"
}
}
示例三:创建ISO云主机
{
"server" : {
"accessIPv4": "1.2.3.4",
"accessIPv6": "80fe::",
"name" : "new-server-iso",
"imageRef" : "8b56fb1c-41cc-4b2d-a773-e8258eb08b62",
"flavorRef" : "1",
"availability_zone": "us-west",
"metadata" : {
"nodeinfo.com:iso-8b56fb1c-41cc-4b2d-a773-e8258eb08b62": "{\"image_uuid\":\"8b56fb1c-41cc-4b2d-a773-e8258eb08b62\",\"boot_order\":1,\"image_name\":\"test_iso\"}",
"nodeinfo.com:bootorder": "{\"order\":[\"hd\",\"cdrom\"]}"
},
"user_data" : "fake_user_data"
},
}
响应消息
参数 | 参数类型 | 描述 |
---|---|---|
server | object | 云主机对象。 |
addresses | ojbect | 云主机地址。 |
created | string | 云主机创建的日期和时间。 |
flavor | object | 云主机使用的规格。 |
hostid | string | 宿主机ID。 |
id | string | 云主机ID。 |
image | object | 创建云主机实例的镜像的UUID和链接信息。 |
key_name | string | 密钥对名称。 |
links | array | 只描述信息。 |
metadata | 元数据键值对。metadata key和value的最大大小都是255字节。 | |
name | string | 云主机名称。 |
accessIPv4 | string | 用于访问此服务器的IPv4地址。 |
accessIPv6 | string | 用于访问此服务器的IPv6地址。 |
OS-DCF:diskConfig | string | 在创建、重新构建或调整服务器大小时,控制API如何对磁盘进行分区。服务器从创建它的映像继承OS-DCF:diskConfig值,映像从创建它的服务器继承OS-DCF:diskConfig值。若要重写继承的设置,可以在服务器创建、重新生成或调整请求的请求主体中包含此属性。如果镜像的OS-DCF:diskConfig值为MANUAL,则不能从该镜像创建服务器,并将其OS-DCF:diskConfig值设置为AUTO。 |
OS-EXT-AZ:availability_zone | string | 可用区域名称。 |
OS-EXT-SRV-ATTR:host | string | 宿主机名字。 |
OS-EXT-SRV-ATTR:hypervisor_hostname | string | 创建服务器的管理程序的主机名。 |
OS-EXT-SRV-ATTR:instance_name | string | 云主机名字。 |
OS-EXT-STS:power_state | integer | 云主机状态。 |
OS-EXT-STS:task_state | string | 云主机工作状态。 |
OS-EXT-STS:vm_state | string | 虚拟机运行状态。 |
os-extended-volumes:volumes_attached | string | 挂载的云盘列表。 |
OS-SRV-USG:launched_at | string | 云主机创建的日期和时间。 |
OS-SRV-USG:terminated_at | string | 云主机删除的日期和时间。 |
progress | integer | 云主机创建进度。 |
security_groups | array | 一个或多个安全组。 |
security_group.name | string | 安全组名称。 |
status | string | 云主机状态。 |
host_status | string | 宿主机状态。 |
tenant_id | string | 云主机租户ID。 |
updated | string | 云主机更新的日期和时间。 |
user_id | string | 云主机用户ID。 |
OS-EXT-SERV-ATTR:hostname | string | 云主机启动时的主机名。 |
OS-EXT-SERV-ATTR:reservation_id | string | 云主机资源预留ID。 |
OS-EXT-SERV-ATTR:launch_index | int | 同时创建多个虚拟机时的顺序。 |
OS-EXT-SERV-ATTR:kernel_id | string | 使用AMI镜像时的内核镜像ID。 |
OS-EXT-SERV-ATTR:ramdisk_id | string | 使用AMI镜像时的内存镜像ID。 |
OS-EXT-SERV-ATTR:root_device_name | string | 云主机系统盘名称。 |
OS-EXT-SERV-ATTR:user_data | string | 启动时使用的配置信息或脚本。必须是Base64编码的。限制为65535字节。 |
estimated_deleted | string | 预计删除时间。 |
响应示例
{
"server": {
"id": "7a2b12f9-1be5-495b-93e5-2a14c6e150ce",
"name": "centos7-init",
"status": "BUILD",
"tenant_id": "a335034a25e942c9b4dc9901b1604898",
"user_id": "719204b70c344d92b42343c12702713f",
"metadata": {},
"hostId": "",
"image": "",
"flavor": {
"id": "7",
"vcpus": 2,
"ram": 2048,
"disk": 0,
"ephemeral": 0,
"swap": 0,
"original_name": "2C-2G",
"extra_specs": {}
},
"created": "2022-07-08T02:35:38Z",
"updated": "2022-07-08T02:35:38Z",
"deleted": "",
"estimated_deleted": "",
"addresses": {},
"accessIPv4": "",
"accessIPv6": "",
"links": [{
"rel": "self",
"href": "http://nova-api.openstack.svc.cluster.local:8774/v2.1/a335034a25e942c9b4dc9901b1604898/servers/7a2b12f9-1be5-495b-93e5-2a14c6e150ce"
}, {
"rel": "bookmark",
"href": "http://nova-api.openstack.svc.cluster.local:8774/a335034a25e942c9b4dc9901b1604898/servers/7a2b12f9-1be5-495b-93e5-2a14c6e150ce"
}],
"OS-DCF:diskConfig": "MANUAL",
"progress": 0,
"OS-EXT-AZ:availability_zone": "default-az",
"config_drive": "",
"key_name": null,
"OS-SRV-USG:launched_at": null,
"OS-SRV-USG:terminated_at": null,
"OS-EXT-SRV-ATTR:host": null,
"OS-EXT-SRV-ATTR:instance_name": "",
"OS-EXT-SRV-ATTR:hypervisor_hostname": null,
"OS-EXT-SRV-ATTR:reservation_id": "r-b4o2epwu",
"OS-EXT-SRV-ATTR:launch_index": 0,
"OS-EXT-SRV-ATTR:hostname": "centos7-init",
"OS-EXT-SRV-ATTR:kernel_id": "",
"OS-EXT-SRV-ATTR:ramdisk_id": "",
"OS-EXT-SRV-ATTR:root_device_name": null,
"OS-EXT-SRV-ATTR:user_data": null,
"OS-EXT-STS:task_state": "scheduling",
"OS-EXT-STS:vm_state": "building",
"OS-EXT-STS:power_state": 0,
"os-extended-volumes:volumes_attached": [],
"host_status": "",
"locked": false,
"description": null,
"tags": [],
"trusted_image_certificates": null
}
}
正常响应代码
例:202
错误码
例:400,401,403,404,409
启动云主机
功能介绍
启动停止的云主机并将其状态更改为“ACTIVE”。
前提条件
- 云主机状态必须为“SHUTOFF”。
故障排除
- 如果云主机状态不变为“ACTIVE”,则启动操作失败。 确保满足前提条件并再次运行请求。 如果请求再次失败,请调查是否正在运行另一个导致竞争条件的操作。
异步后置条件
- 成功启动云主机后,其状态将更改为“ACTIVE”。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
os-start | string | 是 | 启动云主机的动作。 |
请求示例
{
"os-start" : true
}
响应示例
POST操作成功的回复没有任何内容。
正常响应代码
202
关闭云主机
功能介绍
关闭启动状态的云主机。
前提条件
- 云主机状态必须为“ACTIVE”。
异步后置条件
- 成功关闭云主机后,其状态将更改为“SHUTOFF”
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
os-stop | string | 是 | 关闭云主机的动作。 |
请求示例
{
"os-stop" : true
}
响应示例
POST操作成功的回复没有任何内容。
正常响应代码
202
重启云主机
功能介绍
重新启动云主机。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
reboot | object | 是 | 重启云主机的动作。 |
type | string | 是 | 重启的类型,取值范围为[‘HARD’, ‘Hard’, ‘hard’, ‘SOFT’, ‘Soft’, ‘soft’] 其中hard表示硬重启, soft表示软重启。 |
请求示例
{
"reboot": {
"type": "SOFT"
}
}
响应示例
POST操作成功的回复没有任何内容。
正常响应代码
202
暂停云主机
功能介绍
暂停启动状态的云主机。
前提条件
- 云主机状态必须为“ACTIVE”。
异步后置条件
- 成功关闭云主机后,其状态将更改为“PAUSED”
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
pause | none | 是 | 暂停云主机的动作。 |
请求示例
{
"pause" : null
}
响应示例
如果成功,此方法不会在响应正文中返回内容。
正常响应代码
202
恢复云主机
功能介绍
恢复暂停状态的云主机。
前提条件
- 云主机状态必须为“PAUSE”。
异步后置条件
- 成功恢复暂停状态的云主机后,其状态将更改为“ACTIVE”。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
unpause | none | 是 | 恢复云主机的动作。 |
请求示例
{
"unpause" : null
}
响应示例
如果成功,此方法不会在响应正文中返回内容。
正常响应代码
202
挂起云主机
功能介绍
挂起运行状态的云主机。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
suspend | none | 是 | 挂起云主机的动作。 |
请求示例
{
"suspend" : null
}
响应示例
如果成功,此方法不会在响应正文中返回内容。
正常响应代码
202
取消挂起云主机
功能介绍
恢复挂起的云主机并将其状态更改为“ACTIVE”。
前提条件
- 云主机状态必须为“SUSPENDED”。
异步后置条件
- 成功取消挂起状态的云主机后,其状态将更改为“ACTIVE”。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
resume | none | 是 | 取消挂起云主机的动作。 |
请求示例
{
"resume" : null
}
响应示例
如果成功,此方法不会在响应正文中返回内容。
正常响应代码
202
云主机编辑名称
功能介绍
编辑云主机名称。
异步后置条件
- 编辑云主机名称后,云主机名称为更新后的新名称。
URI
PUT /servers/{server_id}
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
server | object | 是 | 包含编辑云主机名称的对象。 |
name | string | 是 | 用户自定义名称。 |
请求示例
{
"server": {
"name": "instance-rename"
}
}
响应示例
{
"server": {
"id": "858e6637-8f46-4362-833b-86d116c772c9",
"name": "instance-rename",
"status": "ACTIVE",
"tenant_id": "955af124d4f94ca98c7c6f62782d4d53",
"user_id": "d39ca7ceb3db46839e9a12ff7bd936a3",
"metadata": {},
"hostId": "e42c4bbfcf7a4d116f753c25c6adfc30c73c1cad34c2399f5690bf05",
"image": "",
"flavor": {
"id": "2",
"vcpus": 1,
"ram": 1024,
"disk": 0,
"ephemeral": 0,
"swap": 0,
"original_name": "1C-1G",
"extra_specs": {}
},
"created": "2022-04-12T08:02:18Z",
"updated": "2022-04-15T06:10:36Z",
"deleted": "",
"estimated_deleted": "",
"addresses": {
"share_net": [
{
"version": 4,
"addr": "192.168.111.177"
}
]
},
"accessIPv4": "",
"accessIPv6": "",
"links": [
{
"rel": "self",
"href": "http://nova-api.openstack.svc.cluster.local:8774/v2.1/aaece80a870b4c5199fe4a27dd866315/servers/858e6637-8f46-4362-833b-86d116c772c9"
},
{
"rel": "bookmark",
"href": "http://nova-api.openstack.svc.cluster.local:8774/aaece80a870b4c5199fe4a27dd866315/servers/858e6637-8f46-4362-833b-86d116c772c9"
}
],
"OS-DCF:diskConfig": "AUTO",
"addresses_labels_mac": [
"fa:16:3e:89:56:91"
],
"progress": 0,
"locked": false,
"description": null,
"tags": [],
"trusted_image_certificates": null
}
}
正常响应代码
200
云主机离线调整规格
功能介绍
离线调整云主机规格。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
resize | object | 是 | 调整云主机规格的动作。 |
flavorRef | string | 是 | 云主机规格ID。 |
请求示例
{
"resize": {
"flavorRef": "214"
}
}
响应示例
如果成功,此方法不会在响应正文中返回内容。
正常响应代码
202
云主机在线调整规格
功能介绍
在线调整云主机规格。
前提条件
- 云主机状态必须为“ACTIVE”。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
live_resize | object | 是 | 调整云主机规格的动作。 |
flavorRef | string | 是 | 云主机规格ID。 |
请求示例
{
"live_resize": {
"flavorRef": "214"
}
}
响应示例
如果成功,此方法不会在响应正文中返回内容。
正常响应代码
202
创建快照
功能介绍
创建云主机快照。
前提条件
- 云主机状态可以为“ACTIVE”,“PAUSE”,“SUSPENDED”。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
createImage | object | 是 | 创建云主机快照的动作。 |
metadata | dict | 否 | 云主机快照元数据。 |
name | string | 是 | 云主机快照名字。 |
请求示例
{
"createImage": {
"name": "zhz111-snapshot1",
"metadata": {
"description": ""
}
}
}
响应示例
如果成功,此方法不会在响应正文中返回内容。
正常响应代码
202
连接网络
功能介绍
为云主机连接一个新的网络。
URI
POST /servers/{server_id}/os-interface
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
interfaceAttachment | object | 是 | 要连接新的网络的数据对象。 |
port_id | string | 否 | 要连接的网卡的id。 |
net_id | string | 否 | 要连接的网络的id。 |
fixed_ips | array | 否 | 网卡的固定ip列表。 |
ip_address | string | 否 | ip地址。 |
请求示例
{
"interfaceAttachment": {
"port_id": "ce155147-9d3b-4c09-9079-da8de0d38df8"
}
}
响应消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
interfaceAttachment | object | 是 | 要连接网络数据对象。 |
port_id | string | 否 | 要连接的网卡的id。 |
net_id | string | 否 | 要连接的网络的id。 |
fixed_ips | array | 否 | 网卡的固定ip列表。 |
ip_address | string | 否 | ip地址。 |
subnet_id | string | 否 | 子网的id。 |
mac_addr | string | 否 | mac地址。 |
port_state | string | 否 | 网卡的状态。 |
响应示例
{
"interfaceAttachment": {
"fixed_ips": [
{
"ip_address": "192.168.1.3",
"subnet_id": "f8a6e8f8-c2ec-497c-9f23-da9616de54ef"
}
],
"mac_addr": "fa:16:3e:4c:2c:30",
"net_id": "3cb9bc59-5699-4588-a4b1-b87f96708bc6",
"port_id": "ce531f90-199f-48c0-816c-13e38010b442",
"port_state": "ACTIVE"
}
}
正常响应代码
200
断开网络
功能介绍
为云主机断开一个连接的网络。
URI
DELETE /servers/{server_id}/os-interface/{port_id}
请求消息
参数 | 是否必选 | 描述 |
---|---|---|
server_id | 是 | 云主机的UUID。 |
port_id | 是 | 要断开的网卡的id。 |
响应示例
如果成功,此方法不会在响应正文中返回内容。
正常响应代码
202
挂载云硬盘
功能介绍
为云主机连接一个新的云硬盘。
注意
如果挂载的是共享云硬盘,需要微版本号大于等于2.60
URI
POST /servers/{server_id}/os-volume_attachments
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
volumeAttachment | object | 是 | 要挂载新的云硬盘的数据对象。 |
volumeId | string | 是 | 要挂载的云硬盘的id。 |
device | string | 否 | 要挂载的云硬盘的名字,例如/dev/vab。 |
注:建议您在请求头中设置如下内容以使用推荐版本的API:”X-OpenStack-Nova-API-Version: 2.67”。
请求示例
{
"volumeAttachment": {
"volumeId": "a26887c6-c47b-4654-abb5-dfadf7d3f803",
"device": "/dev/vdd"
}
}
响应消息
参数 | 参数类型 | 描述 |
---|---|---|
volumeAttachment | object | 要挂载的云硬盘的数据。 |
device | string | 挂载给云主机设备的名称。 |
id | string | 挂载信息的id。 |
serverId | string | 云主机的id。 |
volumeId | string | 云硬盘的id。 |
响应示例
{
"volumeAttachment": {
"device": "/dev/vdd",
"id": "a26887c6-c47b-4654-abb5-dfadf7d3f803",
"serverId": "0c92f3f6-c253-4c9b-bd43-e880a8d2eb0a",
"volumeId": "a26887c6-c47b-4654-abb5-dfadf7d3f803"
}
}
正常响应代码
200
卸载云硬盘
功能介绍
为云主机卸载一个云硬盘。
URI
DELETE /servers/{server_id}/os-volume_attachments/{volume_id}
请求消息
参数 | 是否必选 | 描述 |
---|---|---|
server_id | 是 | 云主机的UUID。 |
volume_id | 是 | 要卸载的云盘的id。 |
响应示例
成功请求时不返回正文。
正常响应代码
202
冷迁移
功能介绍
把虚拟机迁移到其它主机上。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 描述 |
---|---|---|
server_id | string | 云主机的UUID。 |
migrate | object | 迁移对象。 |
host | string | 目标主机。 |
注:建议您在请求头中设置如下内容以使用推荐版本的API:”X-OpenStack-Nova-API-Version: 2.56”。
请求示例
{
"migrate":{
"host":"node-1.domain.tld"
}
}
响应消息
如果成功,此方法不会在响应正文中返回内容。
正常响应代码
202
热迁移
功能介绍
把虚拟机热迁移到其它主机。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 描述 |
---|---|---|
server_id | string | 云主机的UUID。 |
os-migrateLive | object | 热迁移对象。 |
host | string | 目标主机。 |
block_migration | boolean | 块迁移,2.24版本前是布尔型 |
block_migration | string | 块迁移,2.25版本开始是字符串型 |
dislk_over_commit | boolean | 磁盘超配 |
force(可选) | boolean | 指定了目标节点是否强制热迁移 |
注:建议您在请求头中设置如下内容以使用推荐版本的API:”X-OpenStack-Nova-API-Version: 2.25”。
请求示例
{
"os-migrateLive":{
"block_migration":"auto",
"host":"node-2.domain.tld"
}
}
响应消息
如果成功,此方法不会在响应正文中返回内容。
正常响应代码
202
撤离
功能介绍
把虚拟机从故障主机撤离。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 描述 |
---|---|---|
server_id | string | 云主机的UUID。 |
evacuate | string | 撤离对象 |
host(可选) | string | 目的主机 |
adminPass(可选) | string | 管理密码 |
onSharedStorage | boolean | 云主机使用共享存储 |
force(可选) | boolean | 选定目的主机强制撤离 |
注:建议您在请求头中设置如下内容以使用推荐版本的API:”X-OpenStack-Nova-API-Version: 2.25”。
请求示例
{
"evacuate": {
"host": "node-2.domain.tld",
"adminPass": "MySecretPass",
"onSharedStorage": "False"
}
}
响应消息
参数 | 参数类型 | 描述 |
---|---|---|
adminPass(可选) | string | 管理密码 |
正常响应代码
200
重置云主机状态
功能介绍
重置云主机的状态。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
os-resetState | string | 是 | 重置云主机状态的动作。 |
os-resetState.state | string | 是 | 重置云主机的状态,active或者error。 |
请求示例
{
"os-resetState": {
"state": "active"
}
}
响应示例
如果成功,此方法不会在响应正文中返回内容。
正常响应代码
202
锁定云主机
功能介绍
锁定云主机。
接口约束
- 策略默认值仅允许具有管理角色或云主机所有者的用户执行此操作。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
lock | object | 是 | 锁定云主机的动作。 |
请求示例
{
"lock": null
}
响应示例
如果成功,此方法不会在响应正文中返回内容。
正常响应代码
202
解锁云主机
功能介绍
解锁锁定的云主机。
接口约束
- 策略默认值仅允许具有管理角色或云主机所有者的用户执行此操作。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
unlock | none | 是 | 解锁锁定云主机的动作。 |
请求示例
{
"unlock": null
}
响应示例
如果成功,此方法不会在响应正文中返回内容。
正常响应代码
202
重建云主机
功能介绍
重建云主机。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
rebuild | object | 是 | 重建云主机的动作。 |
imageRef | string | 是 | 重建要使用的镜像ID。 |
name | string | 否 | 重建的云主机名称。 |
adminPass | string | 否 | 重建云主机的管理员密码。 |
metadata | string | 否 | 重建云主机要使用的元数据。 |
请求示例
{
"rebuild" : {
"imageRef" : "70a599e0-31e7-49b7-b260-868f441e862b",
"name" : "foobar",
"adminPass" : "seekr3t",
"metadata" : {
"meta_var" : "meta_val"
}
}
}
正常响应代码
202
删除云主机
功能介绍
移动云主机到回收站。
URI
DELETE /servers/{server_id}
请求消息
参数 | 是否必选 | 描述 |
---|---|---|
server_id | 是 | 云主机的UUID。 |
请求示例
DELETE /servers/89b37e3e-592a-4626-a2d4-aa48219b3323
响应消息
对DELETE操作成功的响应没有任何内容。
正常响应代码
204
重置云主机密码
功能介绍
重置云主机管理员密码。
前提条件
- 云主机状态必须为“ACTIVE”。
URI
POST /servers/{server_id}/action
请求消息
参数 | 参数类型 | 是否必选 | 描述 |
---|---|---|---|
server_id | string | 是 | 云主机的UUID。 |
changePassword | object | 是 | 调整云主机密码的动作。 |
adminPass | string | 是 | 要设置的管理员密码。 |
请求示例
{
"changePassword": {
"adminPass": "foo"
}
}
响应示例
POST操作成功的回复没有任何内容。
正常响应代码
202