将PCI设备切分出的MDEV设备绑定到云主机(AttachMdevDeviceToVm)
API请求
URLs
POST zstack/v1/mdev-devices/{mdevDeviceUuid}/vm-instances/{vmInstanceUuid}Headers
Authorization: OAuth the-session-uuidBody
{
"params": {},
"systemTags": [],
"userTags": []
}Note: 上述示例中systemTags、userTags字段可以省略。列出是为了表示body中可以包含这两个字段。
Curl示例
curl -H "Content-Type: application/json;charset=UTF-8" \
-H "Authorization: OAuth b86c9016b4f24953a9edefb53ca0678c" \
-X POST -d '{"params":{}}' http://localhost:8080/zstack/v1/mdev-devices/2a23f189ed803f869deab2b22ef83b4d/vm-instances/e4108c6e45303e3bbd9743093127b894参数列表
| 名字 | 类型 | 位置 | 描述 | 可选值 | 起始版本 |
|---|---|---|---|---|---|
| mdevDeviceUuid | String | url | MDEV设备UUID | 3.5.0 | |
| vmInstanceUuid | String | url | 云主机UUID | 3.5.0 | |
| systemTags (可选) | List | body | 系统标签 | 3.5.0 | |
| userTags (可选) | List | body | 用户标签 | 3.5.0 |
API返回
返回示例
{
"inventory": {
"uuid": "2b29e6effba34e848164039e02511b89",
"name": "GRID M60-2A",
"parentUuid": "e9e3fe7b21644a19ac33e84dd27e3175",
"hostUuid": "af505b47d522413d99d361b93cf92d2a",
"mdevSpecUuid": "072b847576c34b419a29b16f62198e09",
"type": "GPU_Video_Controller",
"state": "Enabled",
"status": "Active",
"createDate": "Nov 14, 2017 10:20:57 PM",
"lastOpDate": "Nov 14, 2017 10:20:57 PM"
}
}| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| error | ErrorCode | 错误码,若不为null,则表示操作失败, 操作成功时该字段为null。 详情参考error | 3.5.0 |
| inventory | MdevDeviceInventory | 详情参考inventory | 3.5.0 |
#error
| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| code | String | 错误码号,错误的全局唯一标识,例如SYS.1000, HOST.1001 | 3.5.0 |
| description | String | 错误的概要描述 | 3.5.0 |
| details | String | 错误的详细信息 | 3.5.0 |
| elaboration | String | 保留字段,默认为null | 3.5.0 |
| opaque | LinkedHashMap | 保留字段,默认为null | 3.5.0 |
| cause | ErrorCode | 根错误,引发当前错误的源错误,若无原错误,该字段为null | 3.5.0 |
#inventory
| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| uuid | String | 资源的UUID,唯一标示该资源 | 3.5.0 |
| name | String | 资源名称 | 3.5.0 |
| description | String | 资源的详细描述 | 3.5.0 |
| parentUuid | String | 物理PCI设备UUID | 3.5.0 |
| hostUuid | String | 物理机UUID | 3.5.0 |
| vmInstanceUuid | String | 云主机UUID | 3.5.0 |
| mdevSpecUuid | String | MDEV设备规格UUID | 3.5.0 |
| createDate | Timestamp | 创建时间 | 3.5.0 |
| lastOpDate | Timestamp | 最后一次修改时间 | 3.5.0 |
| type | MdevDeviceType | 详情参考type | 3.5.0 |
| state | MdevDeviceState | 详情参考state | 3.5.0 |
| status | MdevDeviceStatus | 详情参考status | 3.5.0 |
#type
| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| GPU_Video_Controller | MdevDeviceType | GPU显卡控制器 | 3.5.0 |
#state
| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| Enabled | MdevDeviceState | 启用 | 3.5.0 |
| Disabled | MdevDeviceState | 停用 | 3.5.0 |
#status
| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| Active | MdevDeviceStatus | 就绪 | 3.5.0 |
| Attached | MdevDeviceStatus | 已挂载 | 3.5.0 |
SDK示例
Java
SDK
AttachMdevDeviceToVmAction action = new AttachMdevDeviceToVmAction();
action.mdevDeviceUuid = "2a23f189ed803f869deab2b22ef83b4d";
action.vmInstanceUuid = "e4108c6e45303e3bbd9743093127b894";
action.sessionId = "b86c9016b4f24953a9edefb53ca0678c";
AttachMdevDeviceToVmAction.Result res = action.call();Python
SDK
AttachMdevDeviceToVmAction action = AttachMdevDeviceToVmAction()
action.mdevDeviceUuid = "2a23f189ed803f869deab2b22ef83b4d"
action.vmInstanceUuid = "e4108c6e45303e3bbd9743093127b894"
action.sessionId = "b86c9016b4f24953a9edefb53ca0678c"
AttachMdevDeviceToVmAction.Result res = action.call()