이 페이지에서는 버킷에서 객체 버전 관리 상태를 사용 설정, 중지, 확인하는 방법을 설명합니다. 객체 버전 관리에서 보관되는 객체를 나열, 복원, 삭제하는 방법은 버전 관리된 객체 작업을 참조하세요.
필요한 역할
버킷에서 객체 버전 관리를 설정하고 관리하는 데 필요한 권한을 얻으려면 관리자에게 버킷 또는 버킷을 포함하는 프로젝트에 대해 스토리지 관리자(roles/storage.admin
) IAM 역할을 부여해 달라고 요청하세요. 이 사전 정의된 역할에는 버킷에 대해 객체 버전 관리를 설정하고 관리하는 데 필요한 권한이 포함되어 있습니다. 필요한 정확한 권한을 보려면 필수 권한 섹션을 확장하세요.
필수 권한
storage.buckets.get
storage.buckets.update
storage.buckets.list
- 이 권한은 Google Cloud 콘솔을 사용하여 이 페이지의 안내를 수행하려는 경우에만 필요합니다.
커스텀 역할을 사용하여 이러한 권한을 부여받을 수도 있습니다.
버킷의 역할 부여에 대한 자세한 내용은 버킷에 IAM 사용을 참조하세요. 프로젝트에 대해 역할을 부여하는 방법은 프로젝트에 대한 액세스 관리를 참조하세요.
버킷에 객체 버전 관리 설정
콘솔
- Google Cloud 콘솔에서 Cloud Storage 버킷 페이지로 이동합니다.
버킷 목록에서 객체 버전 관리를 사용 설정하거나 중지할 버킷의 이름을 클릭합니다.
페이지 상단의 보호 탭을 선택합니다.
객체 버전 관리의 현재 상태는 객체 버전 관리 섹션에서 확인할 수 있습니다.
객체 버전 관리 섹션에서 현재 상태를 클릭하여 변경합니다.
객체 버전 관리 대화상자가 나타납니다.
- 객체 버전 관리를 사용 설정하고 스토리지 비용을 최소화하려면 권장 수명 주기 규칙을 추가하여 버전 비용 관리 체크박스를 선택합니다.
확인을 클릭합니다.
명령줄
gcloud storage buckets update
명령어를 적절한 플래그와 함께 사용합니다.
gcloud storage buckets update gs://BUCKET_NAME FLAG
각 항목의 의미는 다음과 같습니다.
BUCKET_NAME
은 관련 버킷의 이름입니다. 예를 들면my-bucket
입니다.FLAG
가--versioning
이면 객체 버전 관리를 사용 설정하고--no-versioning
이면 사용 중지합니다.
성공하면 다음 예시와 비슷한 응답이 표시됩니다.
Updating gs://my-bucket/... Completed 1
클라이언트 라이브러리
C++
자세한 내용은 Cloud Storage C++ API 참고 문서를 확인하세요.
Cloud Storage에 인증하려면 애플리케이션 기본 사용자 인증 정보를 설정합니다. 자세한 내용은 로컬 개발 환경의 인증 설정을 참조하세요.
다음 샘플은 버킷에서 객체 버전 관리를 사용 설정합니다.
다음 샘플은 버킷에서 객체 버전 관리를 사용 중지합니다.
C#
자세한 내용은 Cloud Storage C# API 참고 문서를 확인하세요.
Cloud Storage에 인증하려면 애플리케이션 기본 사용자 인증 정보를 설정합니다. 자세한 내용은 로컬 개발 환경의 인증 설정을 참조하세요.
다음 샘플은 버킷에서 객체 버전 관리를 사용 설정합니다.
다음 샘플은 버킷에서 객체 버전 관리를 사용 중지합니다.
Go
자세한 내용은 Cloud Storage Go API 참고 문서를 확인하세요.
Cloud Storage에 인증하려면 애플리케이션 기본 사용자 인증 정보를 설정합니다. 자세한 내용은 로컬 개발 환경의 인증 설정을 참조하세요.
다음 샘플은 버킷에서 객체 버전 관리를 사용 설정합니다.
다음 샘플은 버킷에서 객체 버전 관리를 사용 중지합니다.
Java
자세한 내용은 Cloud Storage Java API 참고 문서를 확인하세요.
Cloud Storage에 인증하려면 애플리케이션 기본 사용자 인증 정보를 설정합니다. 자세한 내용은 로컬 개발 환경의 인증 설정을 참조하세요.
다음 샘플은 버킷에서 객체 버전 관리를 사용 설정합니다.
다음 샘플은 버킷에서 객체 버전 관리를 사용 중지합니다.
Node.js
자세한 내용은 Cloud Storage Node.js API 참고 문서를 확인하세요.
Cloud Storage에 인증하려면 애플리케이션 기본 사용자 인증 정보를 설정합니다. 자세한 내용은 로컬 개발 환경의 인증 설정을 참조하세요.
다음 샘플은 버킷에서 객체 버전 관리를 사용 설정합니다.
다음 샘플은 버킷에서 객체 버전 관리를 사용 중지합니다.
PHP
자세한 내용은 Cloud Storage PHP API 참고 문서를 확인하세요.
Cloud Storage에 인증하려면 애플리케이션 기본 사용자 인증 정보를 설정합니다. 자세한 내용은 로컬 개발 환경의 인증 설정을 참조하세요.
다음 샘플은 버킷에서 객체 버전 관리를 사용 설정합니다.
다음 샘플은 버킷에서 객체 버전 관리를 사용 중지합니다.
Python
자세한 내용은 Cloud Storage Python API 참고 문서를 확인하세요.
Cloud Storage에 인증하려면 애플리케이션 기본 사용자 인증 정보를 설정합니다. 자세한 내용은 로컬 개발 환경의 인증 설정을 참조하세요.
다음 샘플은 버킷에서 객체 버전 관리를 사용 설정합니다.
다음 샘플은 버킷에서 객체 버전 관리를 사용 중지합니다.
Ruby
자세한 내용은 Cloud Storage Ruby API 참고 문서를 확인하세요.
Cloud Storage에 인증하려면 애플리케이션 기본 사용자 인증 정보를 설정합니다. 자세한 내용은 로컬 개발 환경의 인증 설정을 참조하세요.
다음 샘플은 버킷에서 객체 버전 관리를 사용 설정합니다.
다음 샘플은 버킷에서 객체 버전 관리를 사용 중지합니다.
REST API
JSON API
Authorization
헤더에 대한 액세스 토큰을 생성하려면 gcloud CLI가 설치 및 초기화되어 있어야 합니다.또는 OAuth 2.0 Playground를 사용하여 액세스 토큰을 만들고
Authorization
헤더에 포함할 수 있습니다.다음 정보를 포함하는 JSON 파일을 만듭니다.
{ "versioning": { "enabled": STATE } }
여기서 STATE는
true
또는false
입니다.cURL
을 사용하여PATCH
버킷 요청으로 JSON API를 호출합니다.curl -X PATCH --data-binary @JSON_FILE_NAME \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ -H "Content-Type: application/json" \ "https://storage.googleapis.com/storage/v1/b/BUCKET_NAME?fields=versioning"
각 항목의 의미는 다음과 같습니다.
JSON_FILE_NAME
은 2단계에서 만든 JSON 파일의 경로입니다.BUCKET_NAME
은 관련 버킷의 이름입니다. 예를 들면my-bucket
입니다.
XML API
Authorization
헤더에 대한 액세스 토큰을 생성하려면 gcloud CLI가 설치 및 초기화되어 있어야 합니다.또는 OAuth 2.0 Playground를 사용하여 액세스 토큰을 만들고
Authorization
헤더에 포함할 수 있습니다.다음을 정보를 포함하는 XML 파일을 만듭니다.
<VersioningConfiguration> <Status>STATE</Status> </VersioningConfiguration>
여기서 STATE는
Enabled
또는Suspended
입니다.cURL
을 사용하여PUT
버킷 요청 및versioning
쿼리 문자열 매개변수로 XML API를 호출합니다.curl -X PUT --data-binary @XML_FILE_NAME \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ "https://storage.googleapis.com/BUCKET_NAME?versioning"
각 항목의 의미는 다음과 같습니다.
XML_FILE_NAME
은 2단계에서 만든 XML 파일의 경로입니다.BUCKET_NAME
은 관련 버킷의 이름입니다. 예를 들면my-bucket
입니다.
객체 버전 관리가 사용 설정되면 실시간 객체 버전이 대체되거나 삭제될 때마다 해당 버전은 이전 버전이 됩니다.
객체 버전 관리 사용 설정 여부 확인
버킷에서 객체 버전 관리 사용이 설정되었는지 여부를 확인하려면 다음을 따르세요.
콘솔
- Google Cloud 콘솔에서 Cloud Storage 버킷 페이지로 이동합니다.
버킷 목록의 보호 열에 각 버킷의 객체 버전 관리 상태가 있습니다.
사용 설정하면 객체 버전 관리 텍스트가 나타납니다.
명령줄
gcloud storage buckets describe
명령어를 --format
플래그와 함께 사용합니다.
gcloud storage buckets describe gs://BUCKET_NAME --format="default(versioning)"
여기서 BUCKET_NAME
은 상태를 보려는 버킷의 이름입니다. 예를 들면 my-bucket
입니다.
성공하고 객체 버전 관리가 사용 설정되면 다음 예시와 비슷한 응답이 표시됩니다.
versioning: enabled: true
성공하고 객체 버전 관리가 사용 설정되지 않으면 다음 예시와 비슷한 응답이 표시됩니다.
null
REST API
JSON API
Authorization
헤더에 대한 액세스 토큰을 생성하려면 gcloud CLI가 설치 및 초기화되어 있어야 합니다.또는 OAuth 2.0 Playground를 사용하여 액세스 토큰을 만들고
Authorization
헤더에 포함할 수 있습니다.cURL
을 사용하여GET
버킷 요청으로 JSON API를 호출합니다.curl -X GET \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ "https://storage.googleapis.com/storage/v1/b/BUCKET_NAME?fields=versioning"
여기서
BUCKET_NAME
은 관련 버킷의 이름입니다. 예를 들면my-bucket
입니다.
성공하고 객체 버전 관리가 사용 설정되면 다음 예시와 비슷한 응답이 표시됩니다.
{ "versioning": { "enabled": true } }
성공하고 객체 버전 관리가 사용 설정되지 않으면 다음 예시와 비슷한 응답이 표시됩니다.
{}
XML API
Authorization
헤더에 대한 액세스 토큰을 생성하려면 gcloud CLI가 설치 및 초기화되어 있어야 합니다.또는 OAuth 2.0 Playground를 사용하여 액세스 토큰을 만들고
Authorization
헤더에 포함할 수 있습니다.cURL
을 사용하여GET
버킷 요청 및versioning
쿼리 문자열 매개변수로 XML API를 호출합니다.curl -X GET \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ "https://storage.googleapis.com/BUCKET_NAME?versioning"
여기서
BUCKET_NAME
은 관련 버킷의 이름입니다. 예를 들면my-bucket
입니다.
성공하고 객체 버전 관리가 사용 설정되면 다음 예시와 비슷한 응답이 표시됩니다.
<VersioningConfiguration>
<Status>Enabled</Status>
</VersioningConfiguration>
성공하고 객체 버전 관리가 사용 설정되지 않으면 다음 예시와 비슷한 응답이 표시됩니다.
<VersioningConfiguration/>
다음 단계
- 객체 버전 관리 자세히 알아보기
- 이전 객체 사용 방법 알아보기
- 객체 수명 주기 관리를 사용하여 객체 버전을 자동으로 관리하는 방법 알아보기
- 경합 상태 방지를 위한 요청 전제조건 사용 방법 알아보기