PUT zstack/v1/vm-instances/{vmInstanceUuid}/actions
Authorization: OAuth the-session-uuid
{
"cloneVmInstance": {
"strategy": "InstantStart",
"names": [
"vm1",
"vm2"
],
"full": false
},
"systemTags": [],
"userTags": []
}
curl -H "Content-Type: application/json;charset=UTF-8" \
-H "Authorization: OAuth b86c9016b4f24953a9edefb53ca0678c" \
-X PUT -d '{"cloneVmInstance":{"strategy":"InstantStart","names":["vm1","vm2"],"full":false}}' \
http://localhost:8080/zstack/v1/vm-instances/c4d628c203433f64b062ad07c8edf10d/actions
名字 | 类型 | 位置 | 描述 | 可选值 | 起始版本 |
---|---|---|---|---|---|
vmInstanceUuid | String | url | 云主机UUID | 0.6 | |
strategy (可选) | String | body(包含在cloneVmInstance结构中) | 策略 |
| 0.6 |
names | List | body(包含在cloneVmInstance结构中) | 云主机的名字清单 | 0.6 | |
full (可选) | Boolean | body(包含在cloneVmInstance结构中 | 是否克隆已挂载数据盘 | 2.5.0 | |
systemTags (可选) | List | body | 系统标签 | 0.6 | |
userTags (可选) | List | body | 用户标签 | 0.6 |
affinityGroupUuid::UUID
affinityGroupUuid::5fd71606d5af451d981413f35367a8d6
volumeProvisioningStrategy::ThinProvisioning, volumeProvisioningStrategy::ThickProvisioning
volumeProvisioningStrategy::ThinProvisioning, volumeProvisioningStrategy::ThickProvisioning
该API调用成功后,返回success为true。成功克隆的虚拟机数量由numberOfClonedVm返回。实际过程中,由于资源限制,可能存在部分成功、部分失败的情况。每台虚拟机的克隆失败原因存放在inventories里面的error字段。
{
"result": {
"numberOfClonedVm": 1.0,
"inventories": [
{
"inventory": {
"uuid": "327b60d6b8cd31489ade6f4830bcec16",
"name": "new vm name",
"description": "web server VM",
"zoneUuid": "d886a09330e13282b7a320a98d0a53ec",
"clusterUuid": "f6f07dff7ede3b8cac7c8595a1698832",
"imageUuid": "3b7ff22eb60d38318835817ba6a2b6a2",
"hostUuid": "70c0f5223d083dfea2f1a02f69906306",
"lastHostUuid": "123f7f85f82f3e99940836d97ae18e04",
"instanceOfferingUuid": "001537d10c433857a7a98ae0a362c910",
"rootVolumeUuid": "c8be7ec6a8573d98a580b457a7245141",
"platform": "Linux",
"defaultL3NetworkUuid": "2ac50b85591b3e87b2686c529cf062f9",
"type": "UserVm",
"hypervisorType": "KVM",
"memorySize": 8.589934592E9,
"cpuNum": 1.0,
"allocatorStrategy": "LastHostPreferredAllocatorStrategy",
"createDate": "Nov 14, 2017 10:20:57 PM",
"lastOpDate": "Nov 14, 2017 10:20:57 PM",
"state": "Running",
"allVolumes": [
{
"uuid": "c8be7ec6a8573d98a580b457a7245141",
"name": "Root-Volume-For-VM-327b60d6b8cd31489ade6f4830bcec16",
"primaryStorageUuid": "c2a27c5268493a5cba84b94e37b86b4d",
"vmInstanceUuid": "327b60d6b8cd31489ade6f4830bcec16",
"diskOfferingUuid": "358e00e7245a39b9aa1c1849d6ba9701",
"rootImageUuid": "3b7ff22eb60d38318835817ba6a2b6a2",
"installPath": "/zstack_ps/rootVolumes/acct-36c27e8ff05c4780bf6d2fa65700f22e/vol-c8be7ec6a8573d98a580b457a7245141/c8be7ec6a8573d98a580b457a7245141.qcow2",
"type": "Root",
"format": "qcow2",
"size": 1.073741824E11,
"actualSize": 2.147483648E10,
"deviceId": 0.0,
"state": "Enabled",
"status": "Ready",
"createDate": "Nov 14, 2017 10:20:57 PM",
"lastOpDate": "Nov 14, 2017 10:20:57 PM"
}
]
},
"started": false
}
]
}
}
名字 | 类型 | 描述 | 起始版本 |
---|---|---|---|
success | boolean | 0.6 | |
error | ErrorCode | 错误码,若不为null,则表示操作失败, 操作成功时该字段为null。 详情参考error | 0.6 |
result | CloneVmInstanceResults | 详情参考result | 0.6 |
error | ErrorCode | 详情参考error | 0.6 |
名字 | 类型 | 描述 | 起始版本 |
---|---|---|---|
code | String | 错误码号,错误的全局唯一标识,例如SYS.1000, HOST.1001 | 0.6 |
description | String | 错误的概要描述 | 0.6 |
details | String | 错误的详细信息 | 0.6 |
elaboration | String | 保留字段,默认为null | 0.6 |
opaque | LinkedHashMap | 保留字段,默认为null | 0.6 |
cause | ErrorCode | 根错误,引发当前错误的源错误,若无原错误,该字段为null | 0.6 |
名字 | 类型 | 描述 | 起始版本 |
---|---|---|---|
numberOfClonedVm | int | 0.6 | |
inventories | List | 详情参考inventories | 0.6 |
名字 | 类型 | 描述 | 起始版本 |
---|---|---|---|
error | ErrorCode | 详情参考error | 0.6 |
inventory | VmInstanceInventory | 详情参考inventory | 0.6 |
名字 | 类型 | 描述 | 起始版本 |
---|---|---|---|
code | String | 错误码号,错误的全局唯一标识,例如SYS.1000, HOST.1001 | 0.6 |
description | String | 错误的概要描述 | 0.6 |
details | String | 错误的详细信息 | 0.6 |
elaboration | String | 保留字段,默认为null | 0.6 |
opaque | LinkedHashMap | 保留字段,默认为null | 0.6 |
cause | ErrorCode | 根错误,引发当前错误的源错误,若无原错误,该字段为null | 0.6 |
名字 | 类型 | 描述 | 起始版本 |
---|---|---|---|
uuid | String | 资源的UUID,唯一标示该资源 | 0.6 |
name | String | 资源名称 | 0.6 |
description | String | 资源的详细描述 | 0.6 |
zoneUuid | String | 区域UUID | 0.6 |
clusterUuid | String | 集群UUID | 0.6 |
imageUuid | String | 镜像UUID | 0.6 |
hostUuid | String | 物理机UUID | 0.6 |
lastHostUuid | String | 0.6 | |
instanceOfferingUuid | String | 计算规格UUID | 0.6 |
rootVolumeUuid | String | 根云盘UUID | 0.6 |
platform | String | 0.6 | |
defaultL3NetworkUuid | String | 0.6 | |
type | String | 0.6 | |
hypervisorType | String | 0.6 | |
memorySize | Long | 0.6 | |
cpuNum | Integer | 0.6 | |
cpuSpeed | Long | 0.6 | |
allocatorStrategy | String | 0.6 | |
createDate | Timestamp | 创建时间 | 0.6 |
lastOpDate | Timestamp | 最后一次修改时间 | 0.6 |
state | String | 0.6 | |
vmNics | List | 详情参考vmNics | 0.6 |
allVolumes | List | 详情参考allVolumes | 0.6 |
名字 | 类型 | 描述 | 起始版本 |
---|---|---|---|
uuid | String | 资源的UUID,唯一标示该资源 | 0.6 |
vmInstanceUuid | String | 云主机UUID | 0.6 |
l3NetworkUuid | String | 三层网络UUID | 0.6 |
ip | String | 0.6 | |
mac | String | 0.6 | |
netmask | String | 0.6 | |
gateway | String | 0.6 | |
metaData | String | 0.6 | |
deviceId | Integer | 0.6 | |
createDate | Timestamp | 创建时间 | 0.6 |
lastOpDate | Timestamp | 最后一次修改时间 | 0.6 |
名字 | 类型 | 描述 | 起始版本 |
---|---|---|---|
uuid | String | 资源的UUID,唯一标示该资源 | 0.6 |
name | String | 资源名称 | 0.6 |
description | String | 资源的详细描述 | 0.6 |
primaryStorageUuid | String | 主存储UUID | 0.6 |
vmInstanceUuid | String | 云主机UUID | 0.6 |
diskOfferingUuid | String | 云盘规格UUID | 0.6 |
rootImageUuid | String | 0.6 | |
installPath | String | 0.6 | |
type | String | 0.6 | |
format | String | 0.6 | |
size | Long | 0.6 | |
actualSize | Long | 0.6 | |
deviceId | Integer | 0.6 | |
state | String | 0.6 | |
status | String | 0.6 | |
createDate | Timestamp | 创建时间 | 0.6 |
lastOpDate | Timestamp | 最后一次修改时间 | 0.6 |
isShareable | Boolean | 0.6 |
CloneVmInstanceAction action = new CloneVmInstanceAction();
action.vmInstanceUuid = "c4d628c203433f64b062ad07c8edf10d";
action.strategy = "InstantStart";
action.names = asList("vm1","vm2");
action.full = false;
action.sessionId = "b86c9016b4f24953a9edefb53ca0678c";
CloneVmInstanceAction.Result res = action.call();
CloneVmInstanceAction action = CloneVmInstanceAction()
action.vmInstanceUuid = "c4d628c203433f64b062ad07c8edf10d"
action.strategy = "InstantStart"
action.names = [vm1, vm2]
action.full = false
action.sessionId = "b86c9016b4f24953a9edefb53ca0678c"
CloneVmInstanceAction.Result res = action.call()
学习路径
ZStack Cloud 产品学习路径
快速梳理文档,点击相应文本链接,快速跳转到相应文档的页面,学习 ZStack Cloud 产品。
商务咨询:
400-962-2212 转 1售后咨询:
400-962-2212 转 2商务联系:
sales@zstack.io商务咨询:
400-962-2212 转 1商务联系:
channel@zstack.io商务咨询:
400-962-2212 转 1售后咨询:
400-962-2212 转 2商务联系:
sales@zstack.io商务咨询:
400-962-2212 转 1商务联系:
channel@zstack.io商务咨询:
400-962-2212 转 1商务联系:
channel@zstack.io下载链接已发送至您的邮箱。
如未收到,请查看您的垃圾邮件、订阅邮件、广告邮件。 当您收到电子邮件后,请点击 URL 链接,以完成下载。感谢您使用 ZStack 产品和服务。
成功提交申请。
我们将安排工作人员尽快与您取得联系。感谢您使用 ZStack 产品和服务。
立即体验
联系我们
回到顶部
商务咨询:
400-962-2212 转 1售后咨询:
400-962-2212 转 2商务联系:
sales@zstack.io成功提交申请。
我们将安排工作人员尽快与您取得联系。感谢您使用 ZStack 产品和服务。