영역 및 리전 Persistent Disk와 Google Cloud Hyperdisk를 정기적으로 자동으로 백업하도록 스냅샷 일정을 만듭니다. Compute Engine 워크로드 백업 권장사항은 스냅샷 일정을 사용하는 것입니다.
백업 시 애플리케이션 데이터 상태를 캡처하는 스냅샷 일정을 만들려는 경우(애플리케이션 일관성, 게스트 플러시, 또는 VSS 스냅샷이라고도 함), 자세한 내용은 Linux 애플리케이션 일관성이 있는 디스크 스냅샷 만들기 또는 Windows 애플리케이션 일관성이 있는 디스크 스냅샷 만들기를 참조하세요.
스냅샷 일정 속성에 대한 자세한 내용은 스냅샷 일정 속성을 참조하세요.
시작하기 전에
- 스냅샷 일정에 대한 제한사항을 검토합니다.
-
아직 인증을 설정하지 않았다면 설정합니다.
인증은 Google Cloud 서비스 및 API에 액세스하기 위해 ID를 확인하는 프로세스입니다.
로컬 개발 환경에서 코드 또는 샘플을 실행하려면 다음과 같이 Compute Engine에 인증하면 됩니다.
Select the tab for how you plan to use the samples on this page:
Console
When you use the Google Cloud console to access Google Cloud services and APIs, you don't need to set up authentication.
gcloud
-
Install the Google Cloud CLI, then initialize it by running the following command:
gcloud init
- Set a default region and zone.
-
Compute 인스턴스 관리자(v1)(
roles/compute.instanceAdmin.v1
) -
서비스 계정으로 실행될 수 있는 VM에 연결하려는 경우:
서비스 계정 사용자(v1)(
roles/iam.serviceAccountUser
) -
스냅샷 일정 만들기: 프로젝트 또는 조직에 대한
compute.resourcePolicies.create
권한 -
디스크에 스냅샷 일정 연결:
-
디스크에 대한
compute.disks.addResourcePolicies
권한 - 리소스 정책에 대한
compute.resourcePolicies.use
권한
-
디스크에 대한
-
스냅샷 일정이 있는 디스크 만들기:
- 프로젝트에 대한
compute.disks.create
권한 - 프로젝트에 대한
compute.resourcePolicies.create
권한 - 디스크에 대한
compute.disks.addResourcePolicies
권한
- 프로젝트에 대한
-
Google Cloud 콘솔에서 VM 인스턴스 페이지로 이동합니다.
VM 인스턴스로 이동
남은 단계가 Google Cloud 콘솔에 자동으로 표시됩니다. - VM 인스턴스가 포함된 프로젝트를 선택합니다.
- 이름 열에서 스냅샷 일정을 만들 영구 디스크가 있는 VM의 이름을 클릭합니다.
-
스토리지 에서 스냅샷 일정을 만들 부팅 디스크 또는 추가 디스크의 이름을 클릭합니다. - 수정을 클릭합니다. 작업 더보기 메뉴를 클릭한 후 수정을 클릭해야 할 수 있습니다.
- 스냅샷 일정에서 일정 만들기를 선택합니다.
-
이름에 다음의 스냅샷 일정 이름 중 하나를 입력합니다.
boot-disk-snapshot-schedule
attached-persistent-disk-snapshot-schedule
-
위치 섹션에서 스냅샷 스토리지 위치를 선택합니다. 스냅샷 설정에 정의된 사전 정의되었거나 맞춤설정된 기본 위치가 자동으로 선택됩니다. 선택적으로 다음을 수행해서 스냅샷 설정을 무효화하고 커스텀 스토리지 위치에 스냅샷을 저장할 수 있습니다.
- 스냅샷 일정 만들기를 완료하려면 만들기를 클릭합니다.
- 이 스냅샷 일정을 영구 디스크에 연결하려면 저장을 클릭합니다.
SCHEDULE_NAME
: 스냅샷 일정의 이름SCHEDULE_DESCRIPTION
: 스냅샷 일정에 대한 설명입니다. 설명을 따옴표를 사용하여 묶습니다.MAX_RETENTION_DAYS
: 스냅샷 보관 일수입니다.예를 들어 값이
3
이면 스냅샷이 3일 동안 보관된 후 삭제됩니다.1
이상의 값을 사용해야 합니다.START_TIME
: UTC 시간대의 시작 시간입니다. 시작 시간은 정시에 시작해야 합니다.예를 들면 다음과 같습니다.
- 오후 2시(PST)는
22:00
으로 지정해야 합니다. - 시작 시간을
22:13
으로 설정하면 오류가 발생합니다.
--weekly-schedule-from-file
플래그를 사용하고 파일 내에서 시작 시간을 지정하면 이 플래그를 포함할 필요가 없습니다.- 오후 2시(PST)는
SNAPSHOT_INTERVAL
: 연속 스냅샷 생성 사이의 간격입니다. 스냅샷 빈도 플래그hourly-schedule
,daily-schedule
,weekly-schedule
,weekly-schedule-from-file
을 함께 사용할 수 없습니다. 스냅샷 일정에 하나만 사용할 수 있습니다.- 값 없이
--daily-schedule
플래그를 포함하여 일 단위 일정을 설정합니다. --hourly-schedule
플래그를 1~23 사이의 정수 값으로 설정하여 시간 단위 일정을 설정합니다. 매일 같은 시간에 스냅샷을 생성하려면 24로 균등하게 나누어지는 시간 단위 숫자를 선택합니다. 예를 들어--hourly-schedule
을12
로 설정하면 스냅샷이 12시간마다 생성됩니다.--weekly-schedule
플래그를 스냅샷을 만들 요일로 설정하여 주 단위 일정을 설정합니다. 요일을 정확히 입력해야 하며 값은 대소문자를 구분하지 않습니다. 예를 들어 매주 금요일마다 디스크를 백업하려면 명령어에--weekly-schedule=friday
가 포함됩니다.--weekly-schedule-from-file
플래그를 포함하여 시작 시간을 다르게 지정하고 다른 요일을 지정하는 고급 주 단위 일정을 설정합니다.FILE_NAME
을 주 단위 스냅샷 일정이 포함된 파일 이름으로 바꿉니다. 파일을 사용하여 다른 요일과 다른 시작 시간을 지정할 수 있지만 명령줄에서 여러 주 단위 일정을 직접 지정할 수는 없습니다. 예를 들어 파일에 월요일과 수요일에 두 번의 주간 일정을 지정할 수 있지만 명령줄에서 이 설정을 복제할 수 없습니다.[ {"day": "MONDAY", "startTime": "04:00"}, {"day": "WEDNESDAY", "startTime": "02:00"} ]
파일에 시작 시간을 포함하면 명령줄에서
--start-time
플래그를 설정할 필요가 없습니다. 일정은 UTC 시간대를 사용합니다.
- 값 없이
DELETION_OPTION
: 소스 디스크가 삭제된 경우 스냅샷 처리 방식을 결정합니다. 생성된 모든 스냅샷을 보존하려면 이 플래그를 생략할 수 있습니다. 그렇지 않은 경우apply-retention-policy
를 지정하여 보관 정책의 설정을 사용합니다.- 디스크 삭제 규칙이 포함됩니다.
--on-source-disk-delete
플래그가 기본keep-auto-snapshots
으로 설정되어 자동 생성된 모든 스냅샷을 무기한 유지합니다. 다른 방법으로는 이 플래그를apply-retention-policy
로 설정하여 스냅샷 보관 정책을 사용합니다. - 스토리지 위치가 수동으로
US
로 설정되므로 생성된 모든 스냅샷이 US 멀티 리전에 저장됩니다. env=dev
및media=images
라벨이 생성된 모든 스냅샷에 적용됩니다.- 보관 정책이 10일로 설정됩니다.
PROJECT_ID
: 프로젝트 이름REGION
: 스냅샷 일정 리소스 정책의 위치SCHEDULE_DESCRIPTION
: 스냅샷 일정의 설명SCHEDULE_NAME
: 스냅샷 일정의 이름STORAGE_LOCATION
: 스토리지 위치Google Cloud 콘솔에서 디스크 페이지로 이동합니다.
스냅샷 일정을 연결할 디스크의 이름을 선택합니다. 그러면 디스크 관리 페이지가 열립니다.
디스크 관리 페이지에서
수정을 클릭합니다. 먼저 작업 더보기 메뉴를 클릭해야 할 수 있습니다.스냅샷 일정 드롭다운 메뉴를 사용하여 디스크에 일정을 추가하거나 새 일정을 만듭니다.
새 일정을 만드는 경우 만들기를 클릭합니다.
저장을 클릭하여 작업을 완료합니다.
DISK_NAME
: 기존 디스크의 이름SCHEDULE_NAME
: 스냅샷 일정의 이름ZONE
: 디스크의 위치PROJECT_ID
: 프로젝트 이름ZONE
: 디스크가 있는 영역입니다.REGION
: 스냅샷 일정이 생성된 리전입니다.DISK_NAME
: 디스크의 이름입니다.SCHEDULE_NAME
: 이 디스크에 적용할 스냅샷 일정의 이름입니다.Google Cloud Console에서 디스크 페이지로 이동합니다.
디스크 만들기를 클릭합니다.
필수 입력란을 모두 완료하여 영역(zone) 또는 리전 디스크를 만듭니다.
스냅샷 일정과 동일한 리전에 디스크를 만듭니다.
스냅샷 일정의 필드를 채웁니다.
드롭다운 메뉴를 사용하고 필드에 모두 입력하여 일정을 만듭니다.
만들기를 클릭하여 일정을 만듭니다.
만들기를 클릭하여 디스크를 만듭니다.
DISK_NAME
: 새 디스크의 이름입니다.SCHEDULE_NAME
: 스냅샷 일정의 이름ZONE
: 디스크를 만들 위치. 디스크는 스냅샷 일정과 동일한 리전의 영역에 있어야 합니다.- 스냅샷 일정 관리 알아보기
- 디스크의 스냅샷 일정 정보에서 예약된 스냅샷 빈도, 보관 정책, 이름 지정 규칙에 대해 알아보기
- 스냅샷에서 커스텀 이미지를 만드는 방법 알아보기
- 로그 확인 방법 알아보기
REST
로컬 개발 환경에서 이 페이지의 REST API 샘플을 사용하려면 gcloud CLI에 제공하는 사용자 인증 정보를 사용합니다.
Install the Google Cloud CLI, then initialize it by running the following command:
gcloud init
자세한 내용은 Google Cloud 인증 문서의 REST 사용 인증을 참조하세요.
필수 역할 및 권한
스냅샷 일정을 만드는 데 필요한 권한을 얻으려면 관리자에게 프로젝트에 대한 다음 IAM 역할을 부여해 달라고 요청하세요.
역할 부여에 대한 자세한 내용은 액세스 관리를 참조하세요.
이러한 사전 정의된 역할에는 스냅샷 일정을 만드는 데 필요한 권한이 포함되어 있습니다. 필요한 정확한 권한을 보려면 필수 권한 섹션을 펼치세요.
필수 권한
스냅샷 일정을 만들려면 다음 권한이 필요합니다.
커스텀 역할이나 다른 사전 정의된 역할을 사용하여 이 권한을 부여받을 수도 있습니다.
스냅샷 일정 만들기 개요
스냅샷 일정을 만들 때 하나 이상의 Persistent Disk 또는 Hyperdisk 볼륨에 적용할 수 있는 리소스 정책을 만듭니다.
다음과 같은 방법으로 스냅샷 일정을 만들 수 있습니다.
스냅샷 일정에 암호화 사용
디스크에서 고객 관리 암호화 키(CMEK)를 사용하는 경우 스냅샷 일정을 사용하여 해당 디스크의 스냅샷을 만들면 생성된 모든 스냅샷이 동일한 키로 자동으로 암호화됩니다.
고객 제공 암호화 키(CSEK)를 사용하는 디스크에서는 스냅샷 일정을 사용할 수 없습니다.
스냅샷 일정 만들기
Google Cloud 콘솔, Google Cloud CLI 또는 REST를 사용하여 디스크의 스냅샷 일정을 만들 수 있습니다. 디스크가 있는 리전과 동일한 리전에 스냅샷 일정을 만들어야 합니다. 예를 들어 디스크가
us-west1-a
영역에 있으면us-west1
리전에 스냅샷 일정을 만들어야 합니다. 그러나 스냅샷 일정에 따라 생성된 스냅샷을 다른 위치에 저장하도록 선택할 수 있습니다.콘솔
gcloud
디스크의 스냅샷 일정을 만들려면
gcloud compute resource-policies create snapshot-schedule
명령어를 사용합니다. 일정 빈도를 시간, 일 또는 주 단위로 설정합니다.gcloud compute resource-policies create snapshot-schedule SCHEDULE_NAME \ --description "SCHEDULE_DESCRIPTION" \ --max-retention-days MAX_RETENTION_DAYS \ --start-time START_TIME \ --hourly-schedule SNAPSHOT_INTERVAL \ --daily-schedule \ --weekly-schedule SNAPSHOT_INTERVAL \ --weekly-schedule-from-file FILE_NAME \ --on-source-disk-delete DELETION_OPTION
다음을 바꿉니다.
예시
모든 예시에는 다음 사항이 적용됩니다.
시간 단위 일정:이 예시에서 스냅샷 일정은 22:00 UTC(14:00 PST)에 시작하고 4시간마다 발생합니다.
gcloud compute resource-policies create snapshot-schedule SCHEDULE_NAME \ --description "MY HOURLY SNAPSHOT SCHEDULE" \ --max-retention-days 10 \ --start-time 22:00 \ --hourly-schedule 4 \ --region us-west1 \ --on-source-disk-delete keep-auto-snapshots \ --snapshot-labels env=dev,media=images \ --storage-location US
일 단위 일정:이 예시에서 스냅샷 일정은 22:00 UTC(14:00 PST)에 시작하고 매일 같은 시간에 발생합니다.
--daily-schedule
플래그가 있어야 하지만 연결된 값이 없어야 합니다.gcloud compute resource-policies create snapshot-schedule SCHEDULE_NAME \ --description "MY DAILY SNAPSHOT SCHEDULE" \ --max-retention-days 10 \ --start-time 22:00 \ --daily-schedule \ --region us-west1 \ --on-source-disk-delete keep-auto-snapshots \ --snapshot-labels env=dev,media=images \ --storage-location US
주 단위 일정: 이 예시에서 스냅샷 일정은 22:00 UTC(14:00 PST)에 시작하고 매주 화요일과 목요일에 발생합니다.
gcloud compute resource-policies create snapshot-schedule SCHEDULE_NAME \ --description "MY WEEKLY SNAPSHOT SCHEDULE" \ --max-retention-days 10 \ --start-time 22:00 \ --weekly-schedule tuesday,thursday \ --region us-west1 \ --on-source-disk-delete keep-auto-snapshots \ --snapshot-labels env=dev,media=images \ --storage-location US
REST
스냅샷 일정을 만들려면
resourcePolicies.insert
에 대한POST
요청을 작성합니다. 스냅샷 일정 이름과 스냅샷 빈도를 포함해야 합니다.요청에 스냅샷 스토리지 위치를 수동으로 지정하고 리소스 라벨을 추가할 수도 있습니다.
기본적으로
onSourceDiskDelete
매개변수가keepAutoSnapshots
로 설정됩니다. 즉, 소스 디스크가 삭제되면 해당 디스크의 자동 생성된 스냅샷이 무기한 보관됩니다. 또는 플래그를applyRetentionPolicy
로 설정하여 보관 정책을 적용할 수 있습니다.다음 예시에서는 12:00 UTC(04:00 PST)에 시작하여 매일 반복되는 일 단위 스냅샷 일정을 설정합니다. 또한 이 예시에서는 보관 정책을 5일로 설정하여 스냅샷이 5일 후에 자동으로 삭제됩니다.
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/resourcePolicies { "name": "SCHEDULE_NAME", "description": "SCHEDULE_DESCRIPTION", "snapshotSchedulePolicy": { "schedule": { "dailySchedule": { "startTime": "12:00", "daysInCycle": "1" } }, "retentionPolicy": { "maxRetentionDays": "5" }, "snapshotProperties": { "guestFlush": "False", "labels": { "env": "dev", "media": "images" }, "storageLocations": "STORAGE_LOCATION" } } }
다음을 바꿉니다.
이와 유사하게 주 단위나 월 단위로 일정을 만들 수 있습니다. 주 단위 또는 월 단위 일정 설정에 대한 자세한 내용은
resourcePolicies.insert
메서드를 참조하세요.예를 들어 다음 요청은 화요일 9:00와 목요일 2:00 UTC에 실행하는 주 단위 일정을 만듭니다.
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/resourcePolicies { "name": "SCHEDULE_NAME", "description": "SCHEDULE_DESCRIPTION", "snapshotSchedulePolicy": { "schedule": { "weeklySchedule": { "dayOfWeeks": [ { "day": "Monday", "startTime": "9:00" }, { "day": "Thursday", "startTime": "2:00" } ] } }, "retentionPolicy": { "maxRetentionDays": "5" }, "snapshotProperties": { "guestFlush": "False", "labels": { "production": "webserver" }, "storageLocations": "US" } } }
디스크에 스냅샷 일정 연결
일정을 만든 후에는 이를 기존 디스크에 연결합니다. 콘솔, gcloud CLI 또는 Compute Engine API를 사용하세요.
콘솔
기존 디스크에 스냅샷 일정을 연결합니다.
gcloud
스냅샷 일정을 디스크에 첨부하려면
gcloud disks add-resource-policies
명령어를 사용합니다.gcloud compute disks add-resource-policies DISK_NAME \ --resource-policies SCHEDULE_NAME \ --zone ZONE
다음을 바꿉니다.
REST
스냅샷 일정을 기존 디스크에 연결하려면
disks.addResourcePolicies
에 대한POST
요청을 작성합니다.POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/disks/DISK_NAME/addResourcePolicies { "resourcePolicies": [ "regions/REGION/resourcePolicies/SCHEDULE_NAME" ] }
다음을 바꿉니다.
스냅샷 일정이 있는 디스크 만들기
Google Cloud 콘솔 또는 gcloud CLI를 사용하여 디스크와 스냅샷 일정을 동시에 만들 수 있습니다.
콘솔
gcloud
gcloud disks create
명령어를 사용하여 영역 또는 리전 Persistent Disk와 Hyperdisk를 만들어 스냅샷 일정을 연결합니다.gcloud compute disks create DISK_NAME \ --resource-policies SCHEDULE_NAME \ --zone ZONE
다음을 바꿉니다.
다음 단계
달리 명시되지 않는 한 이 페이지의 콘텐츠에는 Creative Commons Attribution 4.0 라이선스에 따라 라이선스가 부여되며, 코드 샘플에는 Apache 2.0 라이선스에 따라 라이선스가 부여됩니다. 자세한 내용은 Google Developers 사이트 정책을 참조하세요. 자바는 Oracle 및/또는 Oracle 계열사의 등록 상표입니다.
최종 업데이트: 2024-09-05(UTC)
[{ "type": "thumb-down", "id": "hardToUnderstand", "label":"Hard to understand" },{ "type": "thumb-down", "id": "incorrectInformationOrSampleCode", "label":"Incorrect information or sample code" },{ "type": "thumb-down", "id": "missingTheInformationSamplesINeed", "label":"Missing the information/samples I need" },{ "type": "thumb-down", "id": "translationIssue", "label":"번역 문제" },{ "type": "thumb-down", "id": "otherDown", "label":"기타" }] [{ "type": "thumb-up", "id": "easyToUnderstand", "label":"이해하기 쉬움" },{ "type": "thumb-up", "id": "solvedMyProblem", "label":"문제가 해결됨" },{ "type": "thumb-up", "id": "otherUp", "label":"기타" }] -