이 페이지에서는 이중 리전 스토리지를 사용하는 방법을 설명합니다.
필요한 역할
이중 리전 버킷을 만드는 데 필요한 권한을 얻으려면 관리자에게 프로젝트에 대한 스토리지 관리자(roles/storage.admin
) IAM 역할을 부여해 달라고 요청하세요.
이 사전 정의된 역할에는 이중 리전 버킷을 만드는 데 필요한 권한이 포함되어 있습니다. 필요한 정확한 권한을 보려면 필수 권한 섹션을 확장하세요.
필수 권한
storage.buckets.create
storage.buckets.enableObjectRetention
(버킷에 객체 보관 구성을 사용 설정한 경우에만 필요)storage.buckets.list
(Google Cloud 콘솔을 사용하여 버킷을 만들 때만 필요)resourcemanager.projects.get
(Google Cloud 콘솔을 사용하여 버킷을 만들 때만 필요)
커스텀 역할이나 다른 사전 정의된 역할을 사용하여 이 권한을 얻을 수도 있습니다. 어떤 역할이 어떤 권한과 연결되어 있는지 확인하려면 Cloud Storage에 대한 IAM 역할을 참조하세요.
프로젝트에 역할을 부여하는 방법은 프로젝트에 대한 액세스 관리를 참조하세요.
이중 리전 버킷 만들기
이중 리전 버킷을 만들려면 다음 단계를 완료하세요.
콘솔
- Google Cloud 콘솔에서 Cloud Storage 버킷 페이지로 이동합니다.
만들기를 클릭합니다.
버킷 만들기 페이지에서 버킷 정보를 입력합니다. 다음 단계로 이동하려면 계속을 클릭합니다.
버킷 이름 지정에서 버킷 이름 지정 요구사항을 충족하는 이름을 입력합니다.
데이터 저장 위치 선택에서 위치 유형 옆의 이중 리전을 선택합니다. 선택사항: 터보 복제 추가 체크박스를 선택하여 이 기능을 터보 복제와 조합합니다.
위치에 대해 사용할 대륙과 연관된 리전을 선택합니다.
데이터의 기본 스토리지 클래스 선택에서 버킷의 스토리지 클래스를 선택합니다. 버킷에 업로드된 모든 객체에는 기본 스토리지 클래스가 기본적으로 할당됩니다.
객체 데이터 보호 방법 선택에 객체 버전 관리, 보관 정책, 암호화 방법과 같은 사용할 보호 도구를 선택합니다.
만들기를 클릭합니다.
Google Cloud 콘솔에서 실패한 Cloud Storage 작업에 대한 자세한 오류 정보를 가져오는 방법은 문제 해결을 참조하세요.
명령줄
buckets create
명령어를 --location
및 --placement
플래그와 함께 사용합니다.
gcloud storage buckets create gs://BUCKET_NAME --location=MULTI-REGION --placement=REGION_1,REGION_2
각 항목의 의미는 다음과 같습니다.
BUCKET_NAME
은 만들려는 버킷의 이름입니다. 예를 들면my-bucket
입니다.MULTI-REGION
은 기본 리전과 연결된 멀티 리전 코드를 지정합니다. 예를 들어ASIA-SOUTH1
(뭄바이) 및ASIA-SOUTH2
(델리) 리전을 선택할 때는IN
을 사용합니다.REGION_1
은 버킷에 대한 리전의 지리적 위치를 지정합니다. 예를 들면ASIA-EAST1
입니다.REGION_2
은 버킷에 대한 두 번째 리전의 지리적 위치를 지정합니다. 예를 들면ASIA-SOUTHEAST1
입니다.
요청이 성공하면 명령어에서 다음과 같은 메시지를 반환합니다.
Creating gs://BUCKET_NAME/...
gcloud storage
로 버킷을 만들 때 사용 가능한 전체 옵션 목록은 buckets create
옵션을 참조하세요.
클라이언트 라이브러리
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
헤더에 포함할 수 있습니다.name
및location
을 포함해야 하는 버킷에 대한 설정이 포함된 JSON 파일을 생성합니다. 전체 설정 목록은 Buckets:Insert 문서를 참조하세요. 다음은 일반적으로 포함되는 설정입니다.{ "name": "BUCKET_NAME", "location": "MULTI-REGION", "customPlacementConfig": { "dataLocations": ["REGION_1", "REGION_2"] }, "storageClass": "STORAGE_CLASS" }
각 항목의 의미는 다음과 같습니다.
BUCKET_NAME
은 버킷에 지정할 이름이며, 이름 지정 요구사항이 적용됩니다. 예를 들면my-bucket
입니다.MULTI-REGION
은 기본 리전과 연결된 멀티 리전 코드를 지정합니다. 예를 들어ASIA-SOUTH1
(뭄바이) 및ASIA-SOUTH2
(델리) 리전을 선택할 때는IN
을 사용합니다.REGION_1
및REGION_2
는 버킷의 객체 데이터를 저장할 리전입니다. 예를 들면ASIA-EAST1
및ASIA-SOUTHEAST1
입니다.STORAGE_CLASS
는 버킷의 기본 스토리지 클래스입니다. 예를 들면STANDARD
입니다.
-
curl -X POST --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?project=PROJECT_ID"
각 항목의 의미는 다음과 같습니다.
JSON_FILE_NAME
은 2단계에서 만든 JSON 파일의 이름입니다.PROJECT_ID
는 버킷과 연결될 프로젝트의 ID입니다. 예를 들면my-project
입니다.
XML API
Authorization
헤더에 대한 액세스 토큰을 생성하려면 gcloud CLI가 설치 및 초기화되어 있어야 합니다.또는 OAuth 2.0 Playground를 사용하여 액세스 토큰을 만들고
Authorization
헤더에 포함할 수 있습니다.다음을 정보를 포함하는 XML 파일을 만듭니다.
<CreateBucketConfiguration> <LocationConstraint>MULTI-REGION</LocationConstraint> <CustomPlacementConfig> <DataLocations> <DataLocation>REGION_1</DataLocation> <DataLocation>REGION_2</DataLocation> </DataLocations> </CustomPlacementConfig> <StorageClass>STORAGE_CLASS</StorageClass> </CreateBucketConfiguration>
각 항목의 의미는 다음과 같습니다.
-
curl -X PUT --data-binary @XML_FILE_NAME \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ -H "x-goog-project-id: PROJECT_ID" \ "https://storage.googleapis.com/BUCKET_NAME"
각 항목의 의미는 다음과 같습니다.
XML_FILE_NAME
은 2단계에서 만든 XML 파일의 이름입니다.PROJECT_ID
는 버킷과 연결될 프로젝트의 ID입니다. 예를 들면my-project
입니다.BUCKET_NAME
은 버킷에 지정할 이름이며, 버킷 이름 지정 요구사항이 적용됩니다. 예를 들면my-bucket
입니다.
요청에 지원되지 않는 리전이 포함되었으면 오류 메시지가 반환됩니다. 요청이 성공하면 응답이 반환되지 않습니다.
다음 단계
- 터보 복제 자세히 알아보기
- 이중 리전 버킷에서 사용되는 리전 페어링을 포함한 버킷 메타데이터 검색
- 터보 복제 가격 책정에 대해 자세히 알아보거나 가격 책정 예시 확인하기