创建PCI设备规格(CreatePciDeviceOffering)
API请求
URLs
POST zstack/v1/pci-device/pci-device-offeringsHeaders
Authorization: OAuth the-session-uuidBody
{
"params": {
"name": "test",
"vendorId": "10de",
"deviceId": "0e0f"
},
"systemTags": [],
"userTags": []
}Note:
上述示例中systemTags、userTags字段可以省略。列出是为了表示body中可以包含这两个字段。
Curl示例
curl -H "Content-Type: application/json;charset=UTF-8" \
-H "Authorization: OAuth b86c9016b4f24953a9edefb53ca0678c" \
-X POST -d '{"params":{"name":"test","vendorId":"10de","deviceId":"0e0f"}}' \
http://localhost:8080/zstack/v1/pci-device/pci-device-offerings
参数列表
| 名字 | 类型 | 位置 | 描述 | 可选值 | 起始版本 |
|---|---|---|---|---|---|
| name(可选) | String | body(包含在params结构中) | 资源名称 | 2.1 | |
| description (可选) | String | body(包含在params结构中) | 资源的详细描述 | 2.1 | |
| type (可选) | String | body(包含在params结构中) | 2.1 | ||
| vendorId | String | body(包含在params结构中) | 供应商ID | 2.1 | |
| deviceId | String | body(包含在params结构中) | 设备ID | 2.1 | |
| subvendorId (可选) | String | body(包含在params结构中) | 子供应商ID | 2.1 | |
| subdeviceId (可选) | String | body(包含在params结构中) | 子设备ID | 2.1 | |
| resourceUuid (可选) | String | body(包含在params结构中) | 2.1 | ||
| systemTags (可选) | List | body | 2.1 | ||
| userTags (可选) | List | body | 2.1 |
API返回
返回示例
{
"inventory": {
"type": "GPU_Video",
"vendorId": "10de",
"deviceId": "0e0f",
"subvendorId": "10de",
"subdeviceId": "118b"
}
}| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| error | ErrorCode | 错误码,若不为null,则表示操作失败, 操作成功时该字段为null。 详情参考error | 2.1 |
| inventory | PciDeviceOfferingInventory | 详情参考inventory | 2.1 |
#error
| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| code | String | 错误码号,错误的全局唯一标识,例如SYS.1000, HOST.1001 | 2.1 |
| description | String | 错误的概要描述 | 2.1 |
| details | String | 错误的详细信息 | 2.1 |
| elaboration | String | 保留字段,默认为null | 2.1 |
| opaque | LinkedHashMap | 保留字段,默认为null | 2.1 |
| cause | ErrorCode | 根错误,引发当前错误的源错误,若无原错误,该字段为null | 2.1 |
#inventory
| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| uuid | String | 资源的UUID,唯一标示该资源 | 2.1 |
| name | String | 资源名称 | 2.1 |
| description | String | 资源的详细描述 | 2.1 |
| vendorId | String | 2.1 | |
| deviceId | String | 2.1 | |
| subvendorId | String | 2.1 | |
| subdeviceId | String | 2.1 | |
| createDate | Timestamp | 创建时间 | 2.1 |
| lastOpDate | Timestamp | 最后一次修改时间 | 2.1 |
| type | PciDeviceOfferingType | 详情参考type | 2.1 |
| attachedInstanceOfferings | List | 详情参考attachedInstanceOfferings | 2.1 |
| matchedPciDevices | List | 详情参考matchedPciDevices | 2.1 |
#type
| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| GPU_Video | PciDeviceOfferingType | GPU显卡 | 2.1 |
| GPU_Audio | PciDeviceOfferingType | GPU声卡 | 2.1 |
| Generic | PciDeviceOfferingType | 一般设备 | 2.1 |
#attachedInstanceOfferings
| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| id | long | 2.1 | |
| instanceOfferingUuid | String | 计算规格UUID | 2.1 |
| pciDeviceOfferingUuid | String | 2.1 | |
| pciDeviceCount | Integer | 2.1 | |
| metadata | PciDeviceMetaData | 详情参考metadata | 2.1 |
#metadata
| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| metaData | String | 2.1 | |
| metaDataEntries | List | 详情参考metaDataEntries | 2.1 |
#metaDataEntries
| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| key | String | 2.1 | |
| value | String | 2.1 | |
| op | PciDeviceMetaDataOperator | 详情参考op | 2.1 |
#op
| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| Equal | PciDeviceMetaDataOperator | 相等 | 2.1 |
| Unequal | PciDeviceMetaDataOperator | 不等 | 2.1 |
#matchedPciDevices
| 名字 | 类型 | 描述 | 起始版本 |
|---|---|---|---|
| pciDeviceUuid | String | 2.1 | |
| pciDeviceOfferingUuid | String | 2.1 |
SDK示例
Java
SDK
CreatePciDeviceOfferingAction action = new CreatePciDeviceOfferingAction();
action.name = "test";
action.vendorId = "10de";
action.deviceId = "0e0f";
action.sessionId = "0cb0086840314456812971957614aa63";
CreatePciDeviceOfferingAction.Result res = action.call();Python
SDK
CreatePciDeviceOfferingAction action = CreatePciDeviceOfferingAction()
action.name = "test"
action.vendorId = "10de"
action.deviceId = "0e0f"
action.sessionId = "b2dcf8abb771429f8f2484d0f4df428d"
CreatePciDeviceOfferingAction.Result res = action.call()