Object Storage 개요
    • PDF

    Object Storage 개요

    • PDF

    기사 요약

    개요

    네이버 클라우드 플랫폼 Object Storage 는 스토리지 관리와 사용에 필요한 S3 API를 제공합니다.

    버전: Amazon S3 v2006-03-01

    호출 도메인(Endpoint)

    HTTP/HTTPS 프로토콜을 모두 지원하지만 데이터 보호를 위해 HTTPS 사용을 권장합니다.

    리전 별 호출 도메인

    리전리전 이름호출 도메인
    한국kr-standardhttps://kr.object.ncloudstorage.com
    미국서부(New)us-standardhttps://us.object.ncloudstorage.com
    싱가포르(New)sg-standardhttps://sg.object.ncloudstorage.com
    일본(New)jp-standardhttps://jp.object.ncpstorage.com
    독일(New)de-standardhttps://de.object.ncloudstorage.com

    제공 리전은 지속적으로 확대해갈 예정입니다.

    인증키(Credential)

    포탈 마이페이지 > 계정 관리 > 인증키 관리에서 생성한 API 인증키를 사용합니다.

    아래는 S3 API를 사용하여 네이버 클라우드 플랫폼 Object Storage에 접근할 때 사용할 수 있는 모든 오퍼레이션을 설명합니다.
    예를 포함하여 오퍼레이션 사용법에 대한 추가 정보를 확인하려면 버킷 오퍼레이션, 오브젝트 오퍼레이션 페이지를 참고하세요.

    계정 관련 오퍼레이션

    계정 레벨에서는 해당 계정에 속한 버킷 목록을 조회하는 오퍼레이션만 지원합니다. 계정의 버킷 개수는 1,000 개로 제한됩니다.

    오퍼레이션설명
    GET Account(List Buckets)계정에 속한 버킷 목록 조회

    버킷 오퍼레이션

    버킷을 생성, 삭제, 조회, 제어하는 오퍼레이션을 설명합니다.

    버킷 내의 오브젝트 목록 조회 GET Bucket (List Objects) Version 2 는 지원하지 않습니다.

    오퍼레이션설명
    PUT Bucket버킷 생성
    계정의 버킷 개수는 1,000 개로 제한됨
    GET Bucket(List Objects)버킷에 포함된 오브젝트 조회
    한 번에 최대 1,000 개의 오브젝트 나열
    HEAD Bucket버킷 헤더 조회
    DELETE Bucket빈 버킷 삭제
    PUT Bucket ACL버킷에 적용할 접근 제어 목록(ACL) 생성
    GET Bucket ACL버킷에 적용된 접근 제어 목록(ACL) 조회
    PUT Bucket CORS버킷에 적용할 CORS 설정 생성
    GET Bucket CORS버킷에 적용된 CORS 설정 조회
    DELETE Bucket CORS버킷에 적용된 CORS 설정 삭제
    List Multipart Uploads완료되지 않았거나 취소된 멀티파트 업로드 조회

    오브젝트 오퍼레이션

    오브젝트를 생성, 삭제, 조회, 제어하는 오퍼레이션을 설명합니다.

    오퍼레이션설명
    PUT Object버킷에 오브젝트 추가(업로드)
    PUT Object (Copy)오브젝트 복사본 생성
    GET Object오브젝트 조회(다운로드)
    HEAD Object오브젝트 헤더 조회
    DELETE Object버킷에서 오브젝트 삭제
    DELETE Multiple Objects버킷에서 멀티파트 오브젝트 삭제
    PUT Object ACL오브젝트에 적용할 접근 제어 목록(ACL) 생성
    GET Object ACL오브젝트에 적용된 접근 제어 목록(ACL) 조회
    OPTIONS ObjectCORS 설정을 확인하여 특정 요청을 전송할 수 있는지 조회
    Initiate Multipart Upload업로드할 파트 집합에 지정할 업로드 ID 생성
    Upload Part업로드 ID와 연관된 오브젝트의 파트 업로드
    Complete Multipart Upload업로드 ID와 연관된 파트로 분리된 오브젝트 결합
    Abort Multipart Upload업로드를 중단하고 업로드 ID와 연관된 파트 삭제

    공통 헤더

    공통 요청 헤더

    다음 표는 네이버 클라우드 플랫폼 Object Storage에서 지원하는 공통 요청 헤더를 설명합니다.

    네이버 클라우드 플랫폼 Object Storage 는 다음 표에 나열되지 않은 공통 헤더는 요청이 전송됐더라도 무시합니다.

    단, 요청 중 일부는 이 문서에 정의된 바와 같이 다른 헤더를 지원할 수 있습니다.
    인증 헤더 생성에 대한 자세한 내용은 "인증 관리" 페이지에서 확인할 수 있습니다.

    헤더설명
    Authorization필수(AWS Signature Version 4)
    Host필수
    x-amz-date필수, Date로 지정될 수 있음
    x-amz-content-sha256필수
    단, 오브젝트 업로드 시 또는 본문에 요청 정보가 포함된 경우에 해당
    Content-Length필수
    단, 오브젝트 업로드 시에 해당
    청크 인코딩(chunked encoding)이 지원됨
    Content-MD5전송 중인 요청 본문의 128 비트 MD5 해시값
    Expect100-continue인 경우 요청 본문 전송 전에 헤더가 승인될 때까지 대기

    공통 응답 헤더

    다음 표는 공통 응답 헤더를 설명합니다.

    헤더설명
    Content-Length요청 본문의 길이(단위: 바이트)
    Connection연결됐는지 여부
    Date요청 메시지의 타임스탬프
    ETag요청 메시지의 MD5 해시값
    x-amz-request-id요청 시 생성된 고유 식별자

    응답 상태 코드

    오류 코드설명HTTP 상태 코드
    AccessDenied접근이 거부됨403 Forbidden
    BadDigest지정한 Content-MD5가 수신한 내용과 일치하지 않음400 Bad Request
    BucketAlreadyExists요청한 버킷 이름 사용 불가
    해당 버킷의 네임스페이스는 시스템을 이용하는 모든 사용자가 공유함
    다른 이름을 선택한 후 다시 시도 필요
    409 Conflict
    BucketNotEmpty삭제하려는 버킷이 비어 있지 않음409 Conflict
    CredentialsNotSupported해당 요청은 Credentials을 지원하지 않음400 Bad Request
    EntityTooSmall업로드하려는 오브젝트의 크기가 허용되는 최소 크기보다 작음400 Bad Request
    EntityTooLarge업로드하려는 오브젝트의 크기가 허용되는 최대 크기 초과400 Bad Request
    IncompleteBodyContent-Length HTTP 헤더에 값을 지정하지 않음400 Bad Request
    IncorrectNumberOfFilesInPostRequestPOST 요청으로는 파일을 하나만 업로드 가능400 Bad Request
    InlineDataTooLarge인라인 데이터의 크기가 허용된 최대 크기를 초과400 Bad Request
    InternalError내부 오류 발생
    재시도 필요
    500 Internal Server Error
    InvalidAccessKeyId입력한 AWS 액세스 키 아이디가 데이터베이스에 존재하지 않음403 Forbidden
    InvalidArgument유효하지 않은 파라미터400 Bad Request
    InvalidArgument시크릿 키의 MD5 해시값이 잘못됨
    MD5 해시는 Base64 인코딩되어야 함
    400 Bad Request
    InvalidArgumentMD5 해시값이 입력값과 일치하지 않음400 Bad Request
    InvalidBucketName지정한 버킷이 유효하지 않음400 Bad Request
    InvalidBucketState해당 요청은 현재의 버킷 상태로는 유효하지 않음409 Conflict
    InvalidDigest지정한 Content-MD5가 유효하지 않음400 Bad Request
    InvalidEncryptionAlgorithmError지정한 Encryption 요청이 유효하지 않음
    지원되는 값은 AES256
    400 Bad Request
    InvalidLocationConstraint지역 제약 조건이 유효하지 않음400 Bad Request
    InvalidObjectState현재의 오브젝트 상태에서는 해당 오퍼레이션이 유효하지 않음403 Forbidden
    InvalidPart지정된 파트 중 하나 이상을 찾을 수 없음
    해당 파트가 업로드되지 않았거나 지정된 엔티티 태그가 파트의 엔티티 태그와 일치하지 않을 수 있음
    400 Bad Request
    InvalidPartOrder파트 목록이 오름차순으로 정렬되지 않았음
    파트 번호순으로 정렬되어야 함
    400 Bad Request
    InvalidRange요청한 범위를 충족시킬 수 없음416 Requested Range Not Satisfiable
    InvalidRequestAWS4-HMAC-SHA256 알고리즘 사용 필요400 Bad Request
    InvalidSecurity입력한 보안 Credentials 이 유효하지 않음403 Forbidden
    InvalidURI지정된 URI의 구문을 분석할 수 없음400 Bad Request
    KeyTooLong키가 너무 김400 Bad Request
    MalformedACLError입력한 XML 형식이 올바르지 않거나, 게시된 스키마의 유효성을 검사하지 않았음400 Bad Request
    MalformedPOSTRequestPOST 요청 본문의 multipart/form-data 속성값이 올바르지 않음400 Bad Request
    MalformedXML설정이 잘못된 XML(XSD 규정을 따르지 않는 XML)을 전송할 때 발생하는 오류
    오류 메시지: "The XML you provided was not well-formed or did not validate against our published schema."
    400 Bad Request
    MaxMessageLengthExceeded요청이 너무 김400 Bad Request
    MaxPostPreDataLengthExceededError업로드 파일 앞의 POST 요청 필드가 너무 큼400 Bad Request
    MetadataTooLarge메타데이터의 헤더 크기가 허용된 최대 크기 초과400 Bad Request
    MethodNotAllowed지정한 메서드는 이 리소스에 사용 불가405 Method Not Allowed
    MissingContentLengthContent-Length HTTP 헤더 제공 필요411 Length Required
    MissingRequestBodyError빈 XML 문서를 전송할 때 발생하는 오류
    오류 메시지: "Request body is empty."
    400 Bad Request
    NoSuchBucket지정한 버킷이 존재하지 않음404 Not Found
    NoSuchKey지정한 키가 존재하지 않음404 Not Found
    NoSuchUpload지정한 멀티파트 업로드가 존재하지 않음
    업로드 ID가 유효하지 않거나, 멀티파트 업로드가 중단 또는 완료되었을 수 있음
    404 Not Found
    NotImplemented입력한 헤더는 구현되지 않은 기능 의미501 Not Implemented
    OperationAborted조건부 연산이 이 리소스와 충돌하여 재시도 필요409 Conflict
    PreconditionFailed지정한 전제 조건 중 하나 이상이 수행되지 않음412 Precondition Failed
    Redirect임시로 새 위치로 리디렉션함307 Moved Temporarily
    RequestIsNotMultiPartContent버킷 POST 요청에는 enclosure-type multipart/form-data 속성값을 지정해야 함400 Bad Request
    RequestTimeout소켓 연결이 제한 시간 내에 서버에 도달하지 못했음400 Bad Request
    RequestTimeTooSkewed요청 시간과 서버 시간 간의 차이가 너무 큼403 Forbidden
    SignatureDoesNotMatch입력한 서명값이 측정된 서명값과 일치하지 않음
    AWS 시크릿 키와 서명 방식 확인 필요
    403 Forbidden
    ServiceUnavailable요청 빈도 줄여야 함503 Service Unavailable
    SlowDown요청 빈도 줄여야 함503 Slow Down
    TemporaryRedirectDNS를 업데이트하는 동안 버킷으로 리디렉션307 Moved Temporarily
    TooManyBuckets버킷 생성 허용 개수 초과400 Bad Request
    UnexpectedContent해당 요청은 콘텐츠를 지원하지 않음400 Bad Request
    UnresolvableGrantByEmailAddress입력하신 메일 주소와 일치하는 계정이 데이터베이스에 존재하지 않음400 Bad Request
    UserKeyMustBeSpecified버킷 POST 요청은 지정된 필드 이름을 포함해야 함
    필드 이름이 지정돼 있다면 필드 순서 확인 필요
    400 Bad Request

    인증

    네이버 클라우드 플랫폼 Object Storage API의 인증은 Authorization 헤더를 통해 이루어지고, 인증 방법은 Object Storage API 사용 가이드에서 확인하실 수 있습니다.

    접근 제어 목록(ACL)

    네이버 클라우드 플랫폼 Object Storage 서비스를 이용 중인 회원을 대상으로 버킷과 오브젝트에 접근 권한을 부여할 수 있습니다.

    네이버 클라우드 플랫폼 Object Storage 이용신청을 완료한 회원은 Object Storage에서 사용할 수 있는 ID가 발급됩니다.
    이 ID는 버킷과 오브젝트의 접근 권한을 설정할 때 사용됩니다.

    또한 인증없이 접근 가능하도록 public-read, public-write 권한 설정도 가능합니다.

    다음 표는 권한 종류와 해당 권한이 부여된 경우 가능한 오퍼레이션을 설명합니다.

    권한버킷에 부여된 경우오브젝트에 부여된 경우
    READ버킷에 속한 오브젝트 목록 조회 가능오브젝트 데이터와 메타데이터의 읽기가 가능
    WRITE새 오브젝트를 생성하거나 기존 오브젝트의 덮어쓰기 또는 삭제 가능N/A
    READ_ACP버킷의 ACL 조회 가능오브젝트의 ACL 조회 가능
    WRITE_ACP버킷의 ACL 설정 가능오브젝트의 ACL 설정 가능
    FULL_CONTROLREAD, WRITE, READ_ACP, WRITE_ACP 권한으로 가능한 모든 오퍼레이션 수행 가능READ, READ_ACP, WRITE_ACP 권한으로 가능한 모든 오퍼레이션 수행 가능

    다음 표는 NCP 오브젝트 스토리지에서 지원하는 기본 ACL을 설명합니다. 이 표에 언급되지 않은 값은 지원되지 않습니다.

    기본 ACL적용 대상설명
    private버킷, 오브젝트소유자에게 FULL_CONTROL 권한 부여 (default)
    public-read버킷, 오브젝트소유자에게 FULL_CONTROL 권한을 부여하고, 모든 사용자에게 READ 권한 부여
    public-read-write버킷, 오브젝트소유자에게 FULL_CONTROL 권한을 부여하고, 모든 사용자에게 READ와 WRITE 권한 부여
    authenticated-read버킷, 오브젝트소유자에게 FULL_CONTROL 권한을 부여하고, 인증된 사용자에게 READ 권한 부여

    public-read를 포함하여 READ 권한이 버킷에 적용된 경우에는 오브젝트를 조회만 할 수 있을 뿐 오브젝트 자체에는 접근할 수 없습니다.


    이 문서가 도움이 되었습니까?

    What's Next
    Changing your password will log you out immediately. Use the new password to log back in.
    First name must have atleast 2 characters. Numbers and special characters are not allowed.
    Last name must have atleast 1 characters. Numbers and special characters are not allowed.
    Enter a valid email
    Enter a valid password
    Your profile has been successfully updated.