Compute > Image > API v2 가이드

API를 사용하려면 API 엔드포인트와 토큰 등이 필요합니다. API 사용 준비를 참고하여 API 사용에 필요한 정보를 준비합니다.

이미지 API는 image 타입 엔드포인트를 이용합니다. 정확한 엔드포인트는 토큰 발급 응답의 serviceCatalog를 참조합니다.

타입 리전 엔드포인트
image 한국(판교) 리전
한국(평촌) 리전
일본 리전
https://kr1-api-image-infrastructure.nhncloudservice.com
https://kr2-api-image-infrastructure.nhncloudservice.com
https://jp1-api-image-infrastructure.nhncloudservice.com

API 응답에 가이드에 명시되지 않은 필드가 나타날 수 있습니다. 이런 필드는 NHN Cloud 내부 용도로 사용되며 사전 공지 없이 변경될 수 있으므로 사용하지 않습니다.

이미지

이미지 목록 조회

GET /v2/images
X-Auth-Token: {tokenId}

요청

이 API는 요청 본문을 요구하지 않습니다.

이름 종류 형식 필수 설명
tokenId Header String O 토큰 ID
limit Query Integer - 반환할 이미지 개수(기본값은 25)
marker Query UUID - 조회할 이미지 목록의 첫 번째 이미지 ID
정렬 방식에 따라 marker로 지정된 이미지부터 limit만큼의 이미지 목록을 조회
name Query String - 조회할 이미지 이름
visibility Query Enum - 조회할 이미지의 보여 주기 속성
public, private, shared 중 하나의 값만 선택 가능
생략하면 모든 종류의 이미지 목록 반환
owner Query String - 조회할 이미지가 속한 테넌트 ID
status Query Enum - 조회할 이미지 상태
queued: 이미지 변환 중
saving: 이미지 업로드 중
active: 정상
killed: 시스템에서 이미지 삭제
deleted: 삭제된 이미지
pending_delete: 이미지 삭제 대기 중
size_min Query Integer - 조회할 이미지의 최소 크기(바이트)
size_max Query Integer - 조회할 이미지의 최대 크기(바이트)
nhncloud_product Query Enum - 조회할 이미지의 인프라 서비스 종류
compute: Instance 서비스 이미지
gpu: GPU Instance 서비스 이미지
container: NHN Kubernetes 서비스 이미지
sort_key Query String - 이미지 목록을 정렬할 때 사용할 속성
이미지의 모든 속성을 지정 가능, 기본값은 created_at
sort_dir Query Enum - 이미지 목록 정렬 방향
asc(오름차순), desc(내림차순) 중 하나의 값만 선택 가능, 기본값은 내림차순
member_status Query Enum - 공유 받은 이미지의 경우 멤버 상태에 따른 이미지 목록을 조회
accepted, pending, rejected, all 중 하나의 값만 선택 가능
기본값은 accepted

응답

이름 종류 형식 설명
images Body Array 이미지 목록 객체
images.status Body String 이미지 상태
queued, saving, active, killed, deleted, pending_delete 중 하나
images.name Body String 이미지 이름
images.tags Body Array 이미지 태그 목록
images.container_format Body String 이미지 컨테이너 포맷
images.created_at Body Datetime 생성 시각
images.disk_format Body String 이미지 디스크 포맷
images.updated_at Body Datetime 수정 시각
images.min_disk Body Integer 이미지 최소 디스크 요구량(GB)
min_disk 값보다 큰 블록 스토리지에서만 사용할 수 있음
images.protected Body Boolean 이미지 보호 여부
protected=true인 경우 수정 및 삭제 불가
images.id Body UUID 이미지 ID
images.min_ram Body Integer 이미지 최소 메모리 요구량(MB)
min_disk 값보다 큰 인스턴스에서만 사용할 수 있음
images.checksum Body String 이미지 내용 해시값
내부적으로 이미지 유효성 검증을 위해 사용
images.owner Body String 이미지가 속한 테넌트 ID
images.visibility Body Enum 이미지 가시성
public, private, shared 중 하나
images.virtual_size Body Integer 이미지 가상 크기
images.size Body Integer 이미지 실제 크기(바이트)
images.properties Body Object 이미지 속성 객체
이미지별 사용자 지정 속성을 키-값 쌍 형태로 기술
images.self Body URI 이미지 경로
images.file Body String 이미지 파일 경로
images.schema Body URI 이미지 스키마 경로
schema Body URI 이미지 목록 스키마 경로
first Body URI 이미지 목록의 첫 번째 페이지에 해당하는 경로
next Body URI 이미지 목록의 다음 페이지에 해당하는 경로
예시

{
  "images": [
    {
      "container_format": "bare",
      "min_ram": 0,
      "updated_at": "2018-12-11T01:01:35Z",
      "login_username": "centos",
      "file": "/v2/images/1c868787-6207-4ff2-a1e7-ae1331d6829b/file",
      "owner": "c289b99209ca4e189095cdecebbd092d",
      "id": "1c868787-6207-4ff2-a1e7-ae1331d6829b",
      "size": 1778843648,
      "os_distro": "CentOS",
      "self": "/v2/images/1c868787-6207-4ff2-a1e7-ae1331d6829b",
      "disk_format": "qcow2",
      "os_version": "6.10",
      "schema": "/v2/schemas/image",
      "status": "active",
      "description": "CentOS 6.10 (2018.10.23)",
      "tags": [],
      "visibility": "public",
      "os_architecture": "amd64",
      "min_disk": 20,
      "virtual_size": null,
      "name": "CentOS 6.10 (2018.10.23)",
      "hypervisor_type": "qemu",
      "created_at": "2018-10-23T02:17:43Z",
      "protected": true,
      "checksum": "f803c5c15bcf9a75935980a900a04584",
      "os_type": "linux"
    }
  ],
  "schema": "/v2/schemas/images",
  "first": "/v2/images",
  "next": "/v2/images?marker=057f9a69-4e4c-4025-8a69-fa248cd9db94"
}


이미지 보기

GET /v2/images/{imageId}
X-Auth-Token: {tokenId}

요청

이 API는 요청 본문을 요구하지 않습니다.

이름 종류 형식 필수 설명
imageId URL UUID O 조회할 이미지 ID
tokenId Header String O 토큰 ID

응답

이름 종류 형식 설명
status Body String 이미지 상태
name Body String 이미지 이름
tags Body String 이미지 태그 목록
container_format Body String 이미지 컨테이너 포맷
created_at Body Datetime 생성 시각
disk_format Body String 이미지 디스크 포맷
updated_at Body Datetime 수정 시각
min_disk Body Integer 이미지 최소 디스크 요구량(GB)
min_disk 값보다 큰 블록 스토리지에서만 사용할 수 있음
protected Body Boolean 이미지 보호 여부
protected=true인 경우 수정 및 삭제 불가
id Body UUID 이미지 ID
min_ram Body Integer 이미지 최소 메모리 요구량(MB)
min_disk 값보다 큰 인스턴스에서만 사용할 수 있음
checksum Body String 이미지 내용의 해시값
내부적으로 이미지 유효성 검증을 위해 사용
owner Body String 이미지가 속한 테넌트 ID
visibility Body Enum 이미지 가시성
public, private, shared 중 하나
virtual_size Body Integer 이미지 가상 크기
size Body Integer 이미지 실제 크기(바이트)
properties Body Object 이미지 속성 객체
이미지별 사용자 지정 속성을 키-값 쌍 형태로 기술
self Body URI 이미지 경로
file Body String 이미지 파일 경로
schema Body URI 이미지 스키마 경로
예시

{
  "container_format": "bare",
  "min_ram": 0,
  "updated_at": "2018-12-11T01:01:35Z",
  "login_username": "centos",
  "file": "/v2/images/1c868787-6207-4ff2-a1e7-ae1331d6829b/file",
  "owner": "c289b99209ca4e189095cdecebbd092d",
  "id": "1c868787-6207-4ff2-a1e7-ae1331d6829b",
  "size": 1778843648,
  "os_distro": "CentOS",
  "self": "/v2/images/1c868787-6207-4ff2-a1e7-ae1331d6829b",
  "disk_format": "qcow2",
  "os_version": "6.10",
  "schema": "/v2/schemas/image",
  "status": "active",
  "description": "CentOS 6.10 (2018.10.23)",
  "tags": [],
  "visibility": "public",
  "os_architecture": "amd64",
  "min_disk": 20,
  "virtual_size": null,
  "name": "CentOS 6.10 (2018.10.23)",
  "hypervisor_type": "qemu",
  "created_at": "2018-10-23T02:17:43Z",
  "protected": true,
  "checksum": "f803c5c15bcf9a75935980a900a04584",
  "os_type": "linux"
}


이미지 생성

빈 이미지를 생성합니다. NHN Cloud에서 이미지를 사용하려면 이미지 생성 후에 이미지 업로드 API를 이용해 실제 파일을 업로드해야 합니다.

POST /v2/images
X-Auth-Token: {tokenId}

요청

이름 종류 형식 필수 설명
tokenId Header String O 토큰 ID
name Body String O 이미지 이름
container_format Body String - 이미지 컨테이너 포맷
disk_format Body String - 이미지 디스크 포맷
min_disk Body Integer - 이미지 최소 디스크 요구량(GB)
min_ram Body Integer - 이미지 최소 메모리 요구량(MB)
protected Body Boolean - 이미지 보호 여부, true 또는 false
tags Body Array - 이미지 태그 목록
visibility Body String - 이미지 가시성
private, shared 중 하나
os_type Body String O 운영체제 타입
windows, linux 중 하나
os_distro Body String - 운영체제 배포판
os_version Body String - 운영체제 버전
예시

{
    "name": "Ubuntu Image",
    "container_format": "bare",
    "disk_format": "qcow2",
    "os_type": "linux",
    "os_distro": "ubuntu",
    "os_version": "Server 22.04 LTS"
}

응답

이름 종류 형식 설명
status Body String 이미지 상태
queued, saving, active, killed, deleted, pending_delete 중 하나
name Body String 이미지 이름
tags Body String 이미지 태그 목록
container_format Body String 이미지 컨테이너 포맷
created_at Body Datetime 생성 시각
disk_format Body String 이미지 디스크 포맷
updated_at Body Datetime 수정 시각
min_disk Body Integer 이미지 최소 디스크 요구량(GB)
min_disk 값보다 큰 블록 스토리지에서만 사용할 수 있음
protected Body Boolean 이미지 보호 여부
protected=true인 경우 수정 및 삭제 불가
id Body UUID 이미지 ID
min_ram Body Integer 이미지 최소 메모리 요구량(MB)
min_disk 값보다 큰 인스턴스에서만 사용할 수 있음
checksum Body String 이미지 내용의 해시값
내부적으로 이미지 유효성 검증을 위해 사용
owner Body String 이미지가 속한 테넌트 ID
visibility Body Enum 이미지 가시성
private, shared 중 하나
virtual_size Body Integer 이미지 가상 크기
size Body Integer 이미지 실제 크기(바이트)
properties Body Object 이미지 속성 객체
이미지별 사용자 지정 속성을 키-값 쌍 형태로 기술
self Body URI 이미지 경로
file Body String 이미지 파일 경로
schema Body URI 이미지 스키마 경로
os_type Body String 운영체제 타입
windows, linux 중 하나
os_distro Body String 운영체제 배포판
os_version Body String 운영체제 버전
예시

{
    "status": "queued",
    "name": "Ubuntu Image",
    "tags": [],
    "container_format": "bare",
    "created_at": "2015-11-29T22:21:42Z",
    "size": null,
    "disk_format": "qcow2",
    "updated_at": "2015-11-29T22:21:42Z",
    "visibility": "private",
    "locations": [],
    "self": "/v2/images/b2173dd3-7ad6-4362-baa6-a68bce3565cb",
    "min_disk": 0,
    "protected": false,
    "id": "b2173dd3-7ad6-4362-baa6-a68bce3565cb",
    "file": "/v2/images/b2173dd3-7ad6-4362-baa6-a68bce3565cb/file",
    "checksum": null,
    "os_hash_algo": null,
    "os_hash_value": null,
    "os_hidden": false,
    "owner": "bab7d5c60cd041a0a36f7c4b6e1dd978",
    "virtual_size": null,
    "min_ram": 0,
    "schema": "/v2/schemas/image",
    "os_type": "linux",
    "os_distro": "ubuntu",
    "os_version": "Server 22.04 LTS"
}


이미지 업로드

생성한 이미지에 실제 이미지 파일을 업로드합니다.

PUT /v2/images/{imageId}/file
X-Auth-Token: {tokenId}
Content-Type: application/octet-stream

요청

요청 시 Header의 Content-Type을 application/octet-stream으로 설정해야 합니다.

이름 종류 형식 필수 설명
imageId URL UUID O 이미지 ID
tokenId Header String O 토큰 ID
- Body Binary O 업로드할 이미지 파일의 바이너리 데이터

응답

이 API는 응답 본문을 반환하지 않습니다. 요청이 올바르면 상태 코드 204를 반환합니다.


이미지 다운로드

지정한 이미지의 바이너리 데이터를 다운로드합니다.

GET /v2/images/{imageId}/file
X-Auth-Token: {tokenId}

요청

이름 종류 형식 필수 설명
imageId URL UUID O 이미지 ID
tokenId Header String O 토큰 ID

응답

이미지의 바이너리 데이터가 반환됩니다. 요청이 올바르면 상태 코드 200을 반환합니다.


이미지 수정

이미지 수정을 통해 이미지 속성을 변경할 수 있습니다.

PATCH /v2/images/{imageId}
X-Auth-Token: {tokenId}
Content-Type: application/openstack-images-v2.1-json-patch

요청

요청 시 Header의 Content-Type을 application/openstack-images-v2.1-json-patch로 설정해야 합니다.

이름 종류 형식 필수 설명
imageId URL UUID O 수정할 이미지 ID
tokenId Header String O 토큰 ID
op Body Enum O 수정할 작업 유형
add: 속성 추가
replace: 속성 값 수정
remove: 속성 삭제
path Body String O 수정할 속성
/{path} 형식
value Body String - 수정할 속성의 값
예시

// 속성 추가
[
    {
        "op": "add",
        "path": "/metadata1",
        "value": "value1"
    },
    {
        "op": "add",
        "path": "/metadata2",
        "value": "1"
    }
]

// 속성 값 수정
[
    {
        "op": "replace",
        "path": "/metadata1",
        "value": "value2"
    }
]

// 속성 삭제
[
    {
        "op": "remove",
        "path": "/metadata1"
    }
]

응답

이미지 보기와 동일한 응답을 반환합니다.


이미지 삭제

가시성이 public인 이미지는 삭제할 수 없습니다.

DELETE /v2/images/{imageId}
X-Auth-Token: {tokenId}

요청

이 API는 요청 본문을 요구하지 않습니다.

이름 종류 형식 필수 설명
imageId URL String O 삭제할 이미지 ID
tokenId Header String O 토큰 ID

응답

이 API는 응답 본문을 반환하지 않습니다.


이미지 태그

태그 추가하기

지정한 이미지에 태그를 추가합니다.

PUT /v2/images/{imageId}/tags/{tag}
X-Auth-Token: {tokenId}

요청

이 API는 요청 본문을 요구하지 않습니다.

이름 종류 형식 필수 설명
imageId URL UUID O 태그를 추가할 이미지 ID
tag URL String O 추가할 태그 이름(영문 기준 최대 255자)
(주의) _로 시작하는 태그는 사용할 수 없습니다
tokenId Header String O 토큰 ID

응답

이 API는 응답 본문을 반환하지 않습니다.


태그 제거하기

지정한 이미지에서 태그를 제거합니다.

DELETE /v2/images/{imageId}/tags/{tag}
X-Auth-Token: {tokenId}

요청

이 API는 요청 본문을 요구하지 않습니다.

이름 종류 형식 필수 설명
imageId URL UUID O 태그를 제거할 이미지 ID
tag URL String O 제거할 태그 이름
tokenId Header String O 토큰 ID

응답

이 API는 응답 본문을 반환하지 않습니다.


이미지 공유

이미지 공유를 통해 자신의 테넌트에 소속된 이미지를 다른 테넌트에 공유할 수 있습니다. 이미지 공유 방법은 다음과 같습니다.

  1. 이미지 가시성을 shared로 변경합니다.
  2. 공유 받을 테넌트를 이미지의 멤버로 등록합니다.

공유한 이미지는 공유 받은 테넌트에서 바로 사용할 수 있지만 기본적으로 이미지 목록 조회에서는 표시되지 않습니다. 공유 받은 테넌트에서 공유 받은 이미지를 조회하려면 공유 받은 테넌트에서 멤버 상태를 accepted로 변경하거나 이미지 목록 조회 시 쿼리 파라미터의 memeber_statusall로 설정합니다.

가시성 변경

PATCH /v2/images/{imageId}
X-Auth-Token: {tokenId}
Content-Type: application/openstack-images-v2.1-json-patch

요청

이름 종류 형식 필수 설명
imageId URL UUID O 공유할 이미지 ID
tokenId Header String O 토큰 ID
op Body String O replace로 지정
path Body String O /visibility로 지정
value Body String O 변경할 가시성값, private 또는 shared
예시

[
    {
        "op" : "replace",
        "path" : "/visibility",
        "value" : "shared"
    }
]

응답

이미지 보기와 동일한 응답을 반환합니다.


멤버 추가

공유 받을 테넌트를 지정한 이미지의 멤버로 등록합니다.

POST /v2/images/{imageId}/members
X-Auth-Token: {tokenId}

요청

이름 종류 형식 필수 설명
imageId URL UUID O 공유할 이미지 ID
tokenId Header String O 토큰 ID
member Body String O 공유 받을 테넌트 ID
예시

{
    "member": "8989447062e04a818baf9e073fd04fa7"
}

응답

이름 종류 형식 설명
created_at Body Datetime 멤버 생성 시각
YYYY-MM-DDThh:mm:ssZ 형식
image_id Body UUID 공유한 이미지 ID
member_id Body String 이미지를 공유 받은 테넌트 ID
schema Body URI 이미지 멤버에 대한 스키마 경로
status Body Enum 이미지 멤버 상태
pending, accepted 중 하나
예시

{
    "created_at": "2013-09-20T19:22:19Z",
    "image_id": "a96be11e-8536-4910-92cb-de50aa19dfe6",
    "member_id": "8989447062e04a818baf9e073fd04fa7",
    "schema": "/v2/schemas/member",
    "status": "pending",
    "updated_at": "2013-09-20T19:25:31Z"
}


멤버 목록 보기

지정한 이미지를 공유 받은 테넌트 목록을 조회합니다. 반드시 해당 이미지가 소속된 테넌트나 공유 받은 테넌트의 토큰으로 요청합니다.

GET /v2/images/{imageId}/members
X-Auth-Token: {tokenId}

요청

이 API는 요청 본문을 요구하지 않습니다.

이름 종류 형식 필수 설명
imageId URL UUID O 이미지 ID
tokenId Header String O 토큰 ID

응답

이름 종류 형식 설명
members Body Object 멤버 객체 목록
members.created_at Body Datetime 멤버 생성 시각 YYYY-MM-DDThh:mm:ssZ 형식
members.image_id Body UUID 공유한 이미지 ID
members.member_id Body String 이미지를 공유 받은 테넌트 ID
members.schema Body URI 이미지 멤버 스키마 경로
members.status Body Enum 이미지 멤버 상태
pending, accepted 중 하나
schema Body URI 이미지 멤버 목록에 대한 스키마 경로
예시

{
    "members": [
        {
            "created_at": "2013-10-07T17:58:03Z",
            "image_id": "dbc999e3-c52f-4200-bedd-3b18fe7f87fe",
            "member_id": "123456789",
            "schema": "/v2/schemas/member",
            "status": "pending",
            "updated_at": "2013-10-07T17:58:03Z"
        },
        {
            "created_at": "2013-10-07T17:58:55Z",
            "image_id": "dbc999e3-c52f-4200-bedd-3b18fe7f87fe",
            "member_id": "987654321",
            "schema": "/v2/schemas/member",
            "status": "accepted",
            "updated_at": "2013-10-08T12:08:55Z"
        }
    ],
    "schema": "/v2/schemas/members"
}


멤버 상세 보기

지정한 이미지의 특정 멤버에 대한 상세 정보를 반환합니다. 반드시 해당 이미지가 소속된 테넌트나 공유 받은 테넌트의 토큰으로 요청합니다.

GET /v2/images/{imageId}/members/{memberId}
X-Auth-Token: {tokenId}

요청

이 API는 요청 본문을 요구하지 않습니다.

이름 종류 형식 필수 설명
imageId URL UUID O 이미지 ID
memberId URL String O 멤버 ID
tokenId Header String O 토큰 ID

응답

이름 종류 형식 설명
created_at Body Datetime 멤버 생성 시각 YYYY-MM-DDThh:mm:ssZ 형식
image_id Body UUID 공유한 이미지 ID
member_id Body String 이미지를 공유 받은 테넌트 ID
schema Body URI 이미지 멤버 스키마 경로
status Body Enum 이미지 멤버 상태
pending, accepted 중 하나
예시

{
    "status": "pending",
    "created_at": "2013-11-26T07:21:21Z",
    "updated_at": "2013-11-26T07:21:21Z",
    "image_id": "0ae74cc5-5147-4239-9ce2-b0c580f7067e",
    "member_id": "8989447062e04a818baf9e073fd04fa7",
    "schema": "/v2/schemas/member"
}


멤버 상태 변경

공유 받은 테넌트에서 공유 받은 이미지를 승인합니다. 이미지 공유를 승인하면 이미지 목록 조회에서도 해당 이미지가 조회됩니다. 반드시 공유 받은 테넌트의 토큰으로 요청합니다.

PUT /v2/images/{imageId}/members/{memberId}
X-Auth-Token: {tokenId}

요청

이름 종류 형식 필수 설명
imageId URL UUID O 이미지 ID
memberId URL String O 멤버 ID
tokenId Header String O 토큰 ID
status Body Enum O accepted, pending, rejected 중 하나
예시

{
    "status": "accepted"
}

응답

이름 종류 유형 설명
created_at Body Datetime 멤버 생성 시각
YYYY-MM-DDThh:mm:ssZ 형식
image_id Body UUID 공유한 이미지 ID
member_id Body String 이미지를 공유 받은 테넌트 ID
schema Body URI 이미지 멤버 스키마 경로
status Body Enum 이미지 멤버 상태
accpeted,pending,rejected 중 하나
updated_at Body Datetime 멤버 상태 수정 시각
YYYY-MM-DDThh:mm:ssZ 형식
예시

{
    "created_at": "2013-09-20T19:22:19Z",
    "image_id": "a96be11e-8536-4910-92cb-de50aa19dfe6",
    "member_id": "8989447062e04a818baf9e073fd04fa7",
    "schema": "/v2/schemas/member",
    "status": "accepted",
    "updated_at": "2013-09-20T20:15:31Z"
}


멤버 삭제

지정한 이미지의 멤버를 삭제합니다. 공유를 취소할 때 사용합니다. 반드시 지정한 이미지의 소속된 테넌트의 토큰으로 요청해야 합니다.

DELETE /v2/images/{imageId}/members/{memberId}
X-Auth-Token: {tokenId}

요청

이 API는 요청 본문을 요구하지 않습니다.

이름 종류 형식 필수 설명
imageId URL UUID O 이미지 ID
memberId URL String O 멤버 ID
tokenId Header String O 토큰 ID

응답

이 API는 응답 본문을 반환하지 않습니다.

TOP