创建镜像元数据(OpenStack原生)
功能介绍
创建镜像元数据。
调用创建镜像元数据接口成功后,只是创建了镜像的元数据,镜像对应的实际镜像文件并不存在。
URI
POST /v2/images
请求消息
- 请求参数 
    参数 是否必选 参数类型 描述 __os_version 否 String 镜像的操作系统具体版本,取值范围见相关参数取值列表。 如果未指定__os_version,则默认设置为Other Linux (64 bit),不保证该镜像能成功创建虚拟机以及通过该镜像创建的虚拟机能够正常使用。 visibility 否 String 其他租户是否可见。 默认取值为private。创建镜像元数据时,visibility取值只能为private。 name 否 String 镜像名称,如果未指定name的取值,则默认为空,但是使用该镜像创建虚拟机会失败。名称的长度为1~255位。name参数说明请参考镜像属性。默认值为空。 protected 否 Boolean 镜像是否被保护,保护后的镜像不可删除。默认取值为false。 container_format 否 String 容器格式。 默认取值为bare。 disk_format 否 String 镜像格式,目前支持zvhd2、vhd、raw、qcow2、iso。非iso格式时默认值是zvhd2。 tags 否 Array of strings 镜像标签列表。长度为1~255位。默认为空。 说明:tag中key的赋值方式为 "key=value"。例如: "tagkey=tagvalue" min_ram 否 Integer 镜像运行需要的最小内存,单位为MB。参数取值依据云服务器的规格限制。默认取值为0。 min_disk 否 Integer 镜像运行需要的最小磁盘,单位为GB 。取值为40~255GB。 必须大于镜像系统盘容量,否则创建云服务器可能失败。 
请求示例
POST https://{Endpoint}/v2/images
{
    "__os_version": "Ubuntu 14.04 server 64bit",
    "container_format": "bare",
    "disk_format": "vhd",
    "min_disk": 100,
    "min_ram": 1024,
    "name": "test",
    "tags": [
        "test=testvalue",
        "image=imagevalue"
    ],
    "visibility": "private",
    "protected": false
}
 响应消息
- 响应参数 
    参数 参数类型 描述 visibility String 其他租户是否可见。取值为private。 name String 镜像名称,如果未指定name的取值,则默认为空,但是使用该镜像创建虚拟机会失败。名称的长度为1~128位。name参数说明请参考镜像属性。 protected Boolean 镜像是否被保护,保护后的镜像不可删除。取值为false。 container_format String 容器格式。 取值为bare。 disk_format String 镜像格式,目前支持zvhd2、vhd、raw、qcow2、iso。非iso格式时默认值是zvhd2。。 tags Array of strings 镜像标签列表。长度为1~255位。 min_ram Integer 镜像运行最小内存,单位为MB。取值参考ECS规格限制,一般设置为0。 min_disk Integer 镜像运行需要的最小磁盘容量,单位为GB 。取值为40~255GB。必须大于镜像系统盘容量,否则创建云服务器可能失败。 status String 镜像状态。取值如下: - queued:表示镜像元数据已经创建成功,等待上传镜像文件。
- saving:表示镜像正在上传文件到后端存储。
- deleted:表示镜像已经删除。
- killed:表示镜像上传错误。
- active:表示镜像可以正常使用。
 created_at String 创建时间。格式为UTC时间。 updated_at String 更新时间。格式为UTC时间。 self String 本镜像链接。 id String 镜像ID。用户调用创建镜像接口后,需保存该镜像的ID,用来调用上传镜像接口完成镜像上传。 file String 上传下载镜像文件的地址链接。 schema String 视图链接。 __image_source_type String 镜像后端存储类型,目前支持uds。 __image_size String 镜像大小。单位为字节。 __isregistered String 镜像是否注册。只有已注册的镜像才能在Portal界面上查询到。取值为true。 __os_version String 镜像的操作系统具体版本,取值范围见相关参数取值列表。 __os_type String 镜像的操作系统类型,取值由__os_version确定。支持Windows、Linux、other。 __platform String 表示镜像支持的操作系统平台。取值由__os_version确定。 __os_bit String 表示操作系统位数。取值由__os_version确定,取值为32或64。 __imagetype String 镜像类型。取值为private,表示私有镜像。 virtual_env_type String 平台类型。 镜像使用环境类型:FusionCompute、Ironic、DataImage、IsoImage。 - 如果是云服务器镜像,则取值为FusionCompute。
- 如果是数据盘镜像,则取值为DataImage。
- 如果是裸金属服务器镜像,则取值为Ironic。
- 如果是ISO镜像,则取值是IsoImage。
 owner String 镜像所属项目ID。 __root_origin String 表示当前镜像来源是从外部导入。取值:file。 checksum String 镜像文件md5值。 size Long 目前暂时不使用。 virtual_size Integer 镜像虚拟大小。单位为字节。 properties Properties object 镜像属性的集合,不表示具体的镜像属性。 
- 响应样例
    STATUS CODE 201 { "schema": "/v2/schemas/image", "min_disk": 100, "created_at": "2016-06-02T07:49:48Z", "__image_source_type": "uds", "container_format": "bare", "__image_size": "0", "file": "/v2/images/4ca46bf1-5c61-48ff-b4f3-0ad4e5e3ba86/file", "updated_at": "2016-06-02T07:49:49Z", "protected": false, "id": "4ca46bf1-5c61-48ff-b4f3-0ad4e5e3ba86", "__isregistered": "true", "min_ram": 1024, "owner": "b912fb4a4c464b568ecfca1071b21b10", "__os_type": "Linux", "__imagetype": "private", "visibility": "private", "virtual_env_type": "FusionCompute", "tags": [ "test=testvalue", "image=imagevalue" ], "__platform": "Ubuntu", "__os_bit": "64", "__os_version": "Ubuntu 14.04 server 64bit", "name": "test", "self": "/v2/images/4ca46bf1-5c61-48ff-b4f3-0ad4e5e3ba86", "disk_format": "vhd", "status": "queued" }
 
    