Cloud Composer 1 | Cloud Composer 2 | Cloud Composer 3
Halaman ini menjelaskan cara mengonfigurasi lingkungan untuk menyimpan snapshot sesuai jadwal.
Untuk mengetahui informasi selengkapnya tentang cara kerja snapshot lingkungan dan cara menyimpan snapshot secara manual, lihat Menyimpan dan memuat snapshot.
Cara kerja snapshot terjadwal
Saat Anda mengaktifkan snapshot terjadwal, Cloud Composer akan menyimpan snapshot lingkungan Anda ke bucket Cloud Storage secara berkala.
Jika Anda membuat snapshot secara manual, Cloud Composer akan menyimpan snapshot di bucket lingkungan secara default. Untuk snapshot terjadwal, sebaiknya simpan snapshot di bucket terpisah. Dengan cara ini, Anda dapat menyiapkan izin dan konfigurasi siklus proses untuk bucket ini. Satu bucket dapat menyimpan snapshot dari beberapa lingkungan, dan Anda juga dapat membuat bucket yang redundant di seluruh region.
Sebelum memulai
Untuk mengetahui informasi selengkapnya tentang persyaratan dan batasan snapshot, lihat Menyimpan dan memuat snapshot.
Cloud Composer mendukung snapshot terjadwal di versi 2.0.32 dan yang lebih baru. Snapshot lingkungan didukung di versi 2.0.9 dan yang lebih baru.
Membuat bucket untuk snapshot terjadwal
Buat bucket untuk snapshot terjadwal. Pertimbangkan cara Anda ingin menggunakan snapshot lingkungan. Jika bucket tersebut merupakan bagian dari disaster recovery plan Anda, gunakan bucket yang redundan di seluruh region atau bucket di region yang berbeda, sehingga Anda memiliki akses ke data meskipun terjadi gangguan layanan regional penuh. Jika tidak, bucket di region yang sama dengan lingkungan mungkin lebih cocok, dan dalam hal ini Anda akan mengurangi biaya transfer data antar-region.
Mengonfigurasi izin untuk bucket
Konfigurasikan izin berikut:
Akun layanan lingkungan Anda harus memiliki izin baca dan tulis untuk bucket ini. Misalnya, peran Storage Object Admin memiliki izin tersebut.
Akun pengguna tidak memerlukan izin tambahan agar bucket dapat memuat snapshot darinya, kecuali jika Anda ingin melihat konten bucket dari konsol Google Cloud. Dalam hal ini, akun pengguna harus memiliki izin baca di bucket.
Menetapkan konfigurasi siklus proses untuk bucket
Untuk menghemat biaya penyimpanan, Anda dapat mengonfigurasi aturan yang menghapus snapshot lingkungan setelah jangka waktu tertentu.
Misalnya, untuk otomatis menghapus snapshot yang lebih lama dari 30 hari:
- Tetapkan konfigurasi siklus proses untuk bucket.
- Tentukan tindakan Delete object.
- Pilih Usia dan 30 hari sebagai kondisi.
Mengaktifkan jadwal snapshot untuk lingkungan Anda
Konsol
Di konsol Google Cloud, buka halaman Environments.
Di daftar lingkungan, klik nama lingkungan Anda. Halaman Environment details akan terbuka.
Buka tab Konfigurasi lingkungan.
Di Recovery configuration > Snapshot schedule, klik Edit. Panel Jadwal snapshot akan terbuka.
Di panel Snapshot schedule, pilih Create snapshots periodically, according to the specified schedule.
Di menu drop-down Frekuensi jadwal, pilih periode harian, mingguan, atau kustom untuk snapshot.
Anda dapat menentukan jadwal kustom dengan format unix-cron. Misalnya, untuk menyimpan snapshot setiap 30 menit, tentukan
*/30 * * * *
.Di kolom Snapshot location, pilih folder bucket tempat Anda ingin menyimpan snapshot.
gcloud
Perbarui konfigurasi lingkungan Anda. Argumen berikut menentukan parameter untuk snapshot terjadwal:
--enable-scheduled-snapshot-creation
mengaktifkan snapshot terjadwal.--snapshot-location
menentukan folder bucket tempat Anda ingin menyimpan snapshot.--snapshot-creation-schedule
menentukan frekuensi pengambilan ringkasan lingkungan, dalam format unix-cron. Misalnya, untuk membuat snapshot setiap 30 menit, tentukan*/30 * * * *
.--snapshot-schedule-timezone
menentukan zona waktu untuk jadwal. Nilai ini adalah offset waktu dan tidak memperhitungkan perubahan waktu musim panas. Nilai yang valid adalah dariUTC-12
hinggaUTC+12
. Contoh:UTC
,UTC-01
,UTC+03
.
gcloud beta composer environments update ENVIRONMENT_NAME \
--location LOCATION \
--enable-scheduled-snapshot-creation \
--snapshot-location "gs://SNAPSHOTS_FOLDER" \
--snapshot-creation-schedule "CRON_EXPRESSION" \
--snapshot-schedule-timezone "TIME_ZONE"
Ganti:
ENVIRONMENT_NAME
dengan nama lingkungan.LOCATION
dengan region tempat lingkungan tersebut berada.SNAPSHOTS_FOLDER
dengan URI folder bucket tempat menyimpan snapshot.CRON_EXPRESSION
dengan jadwal, dalam format unix-cron.TIME_ZONE
dengan zona waktu untuk jadwal.
Contoh (setiap hari pukul 04.00, UTC+01):
gcloud beta composer environments update example-environment \
--location us-central1 \
--enable-scheduled-snapshot-creation \
--snapshot-location "gs://example-bucket/environment_snapshots" \
--snapshot-creation-schedule "0 4 * * *" \
--snapshot-schedule-timezone "UTC+01"
API
Buat permintaan API environments.patch
.
Dalam permintaan ini:
Di parameter
updateMask
, tentukan maskconfig.recoveryConfig.scheduledSnapshotsConfig
untuk mengganti konfigurasi snapshot terjadwal yang ada.Dalam isi permintaan, tentukan konfigurasi untuk snapshot:
{ "config": { "recoveryConfig": { "scheduledSnapshotsConfig": { "enabled": true, "snapshot_location": "gs://SNAPSHOTS_FOLDER", "snapshot_creation_schedule": "CRON_EXPRESSION", "time_zone": "TIME_ZONE" } } } }
Ganti:
SNAPSHOTS_FOLDER
dengan URI folder bucket tempat menyimpan snapshot.CRON_EXPRESSION
dengan jadwal, dalam format unix-cron.TIME_ZONE
dengan zona waktu untuk jadwal. Nilai ini adalah offset waktu dan tidak memperhitungkan perubahan waktu musim panas. Nilai yang valid adalah dariUTC-12
hinggaUTC+12
. Contoh:UTC
,UTC-01
,UTC+03
.
Contoh (setiap hari pukul 04.00, UTC+01):
// PATCH https://composer.googleapis.com/v1beta1/projects/example-project/ // locations/us-central1/environments/example-environment?updateMask= // config.recoveryConfig.scheduledSnapshotsConfig { "config": { "recoveryConfig": { "scheduledSnapshotsConfig": { "enabled": true, "snapshot_location": "gs://example-bucket/environment_snapshots", "snapshot_creation_schedule": "0 4 * * *", "time_zone": "UTC+01" } } } }
Terraform
scheduled_snapshots_config
di blok recovery_config
menentukan
parameter untuk snapshot terjadwal:
enabled
mengaktifkan snapshot terjadwal.snapshot_location
menentukan folder bucket tempat Anda ingin menyimpan snapshot.snapshot_creation_schedule
menentukan frekuensi pengambilan ringkasan lingkungan, dalam format unix-cron. Misalnya, untuk membuat snapshot setiap 30 menit, tentukan*/30 * * * *
.
resource "google_composer_environment" "example" {
provider = google-beta
name = "ENVIRONMENT_NAME"
region = "LOCATION"
recovery_config {
scheduled_snapshots_config {
enabled = true
snapshot_location = "gs://SNAPSHOTS_FOLDER"
snapshot_creation_schedule = "CRON_EXPRESSION"
time_zone = "TIME_ZONE"
}
}
}
Ganti:
SNAPSHOTS_FOLDER
dengan URI folder bucket tempat menyimpan snapshot.CRON_EXPRESSION
dengan jadwal, dalam format unix-cron.TIME_ZONE
dengan zona waktu untuk jadwal. Nilai ini adalah offset waktu dan tidak memperhitungkan perubahan waktu musim panas. Nilai yang valid adalah dariUTC-12
hinggaUTC+12
. Contoh:UTC
,UTC-01
,UTC+03
.
Contoh (setiap hari pukul 04.00, UTC+01):
resource "google_composer_environment" "example" {
provider = google-beta
name = "example-environment"
region = "us-central1"
recovery_config {
scheduled_snapshots_config {
enabled = true
snapshot_location = "gs://example-bucket/environment_snapshots"
snapshot_creation_schedule = "0 4 * * *"
time_zone = "UTC+01"
}
}
}
Menonaktifkan snapshot terjadwal
Jika Anda menonaktifkan snapshot terjadwal, semua snapshot yang ada yang sudah diambil tidak akan diubah atau dihapus. Snapshot ini tetap berada di lokasi tempat diperbarui.
Konsol
Di konsol Google Cloud, buka halaman Environments.
Di daftar lingkungan, klik nama lingkungan Anda. Halaman Environment details akan terbuka.
Buka tab Konfigurasi lingkungan.
Di Recovery configuration > Snapshot schedule, klik Edit. Panel Jadwal snapshot akan terbuka.
Di panel Jadwal snapshot, pilih Jangan buat snapshot secara otomatis.
gcloud
Perbarui konfigurasi lingkungan Anda. Argumen
--disable-scheduled-snapshot-creation
menonaktifkan snapshot
terjadwal.
gcloud beta composer environments update ENVIRONMENT_NAME \
--location LOCATION \
--disable-scheduled-snapshot-creation
Ganti:
ENVIRONMENT_NAME
dengan nama lingkungan.LOCATION
dengan region tempat lingkungan tersebut berada.
Contoh:
gcloud beta composer environments update example-environment \
--location us-central1 \
--disable-scheduled-snapshot-creation
API
Buat permintaan API environments.patch
.
Dalam permintaan ini:
Dalam parameter
updateMask
, tentukan maskconfig.recoveryConfig.scheduledSnapshotsConfig.enabled
untuk mengganti nilai kolomenabled
.Dalam isi permintaan, tentukan nilai baru:
{ "config": { "recoveryConfig": { "scheduledSnapshotsConfig": { "enabled": false } } } }
Contoh:
// PATCH https://composer.googleapis.com/v1beta1/projects/example-project/
// locations/us-central1/environments/example-environment?updateMask=
// config.recoveryConfig.scheduledSnapshotsConfig.enabled
{
"config": {
"recoveryConfig": {
"scheduledSnapshotsConfig": {
"enabled": false
}
}
}
}
Terraform
Untuk menonaktifkan snapshot terjadwal, tetapkan kolom enabled
di blok scheduled_snapshots_config
ke false
:
resource "google_composer_environment" "example" {
provider = google-beta
name = "ENVIRONMENT_NAME"
region = "LOCATION"
recovery_config {
scheduled_snapshots_config {
enabled = false
}
}
}
Contoh:
resource "google_composer_environment" "example" {
provider = google-beta
name = "example-environment"
region = "us-central1"
recovery_config {
scheduled_snapshots_config {
enabled = false
// Other scheduled snapshots parameters
}
}
}