Anda dapat memulihkan cadangan database Spanner ke dalam database baru. Database yang
dipulihkan akan memiliki semua data dan skema dari database asli
pada version_time cadangan, termasuk semua opsi database yang ditetapkan
dengan perintah ALTER DATABASE SET OPTIONS. Namun, hal berikut tidak disertakan dalam database yang dipulihkan:
- Izin Identity and Access Management (IAM) (kecuali izin yang diwarisi dari instance yang berisi database yang dipulihkan). Anda harus menerapkan izin IAM yang sesuai setelah pemulihan selesai.
- Data internal dari setiap aliran perubahan.
- Time to live (TTL) yang ditentukan oleh kebijakan penghapusan baris. Anda harus mengonfigurasi ulang kebijakan ini setelah pemulihan selesai. Untuk mengetahui informasi selengkapnya, lihat Cadangan dan TTL.
- Titik pemisahan yang Anda buat saat melakukan pra-pemisahan database. Untuk mengetahui informasi selengkapnya, lihat Ringkasan pra-pemisahan.
Anda dapat menggunakan pemulihan dari cadangan dengan cara berikut:
- Di Google Cloud konsol
- Menggunakan Google Cloud CLI
- Menggunakan library klien
- Menggunakan REST atau RPC API
Cara kerja pemulihan database dari cadangan
Saat memulihkan database Spanner, Anda harus menentukan cadangan sumber dan database target baru. Anda tidak dapat memulihkan ke database yang ada. Database yang baru dipulihkan harus berada dalam project yang sama dengan cadangan dan berada dalam instance dengan konfigurasi instance yang sama dan edisi Spanner yang sama (atau tingkat yang lebih tinggi) dengan cadangan. Untuk memulihkan cadangan ke instance dengan konfigurasi instance yang berbeda atau dalam project yang berbeda, Anda dapat menyalin cadangan terlebih dahulu ke region atau project target.
Misalnya, jika cadangan berada dalam instance yang dikonfigurasi us-west3 dan menggunakan edisi Enterprise, cadangan tersebut dapat dipulihkan ke instance mana pun dalam project yang juga dikonfigurasi us-west3 dan menggunakan edisi Enterprise. Namun, untuk memulihkan cadangan tersebut ke instance yang dikonfigurasi us-east1 atau ke instance dalam project yang berbeda, Anda harus menyalin cadangan terlebih dahulu ke instance di region atau project target, lalu memulihkan dari cadangan yang disalin. Jika Anda memulihkan cadangan dalam instance edisi Enterprise ke dalam instance edisi Standar, pemulihan mungkin akan gagal jika database menggunakan fitur edisi Enterprise. Kapasitas komputasi instance
tidak harus sama.
Proses pemulihan dirancang untuk ketersediaan tinggi. Anda dapat memulihkan database asalkan kuorum mayoritas region dan zona di instance target tersedia.
Untuk memulihkan cadangan yang mendukung CMEK, kunci dan versi kunci harus tersedia untuk Spanner. Database yang dipulihkan, secara default, menggunakan konfigurasi enkripsi yang sama dengan cadangan. Anda dapat mengganti perilaku ini dengan menentukan konfigurasi enkripsi yang berbeda saat memulihkan database. Untuk mengetahui informasi selengkapnya, lihat memulihkan dari cadangan yang mendukung CMEK.
Anda tidak dapat memulihkan cadangan yang menggunakan fitur edisi tingkat yang lebih tinggi ke a tingkat yang lebih rendah edisi. Misalnya, jika instance Anda menggunakan partisi geografis, Anda tidak dapat memulihkannya ke edisi Enterprise atau edisi Standar.
Memulihkan cadangan ke region atau project lain
Jika Anda perlu memulihkan cadangan ke region atau project lain, pertama, salin cadangan ke region atau project yang dipilih. Anda dapat memulihkan cadangan yang disalin segera setelah penyalinan selesai. Sebelum memulihkan, pastikan instance tujuan memiliki node atau unit pemrosesan yang cukup untuk mendukung ukuran database sesuai dengan batas penyimpanan 10 TB per node. Misalnya, Anda memerlukan minimal 2 node untuk memulihkan cadangan 20 TB. Jika Anda telah menyalin cadangan ke project lain, dan jika Anda ingin memulihkannya di sana, pastikan project tujuan Anda memiliki kuota node yang cukup yang diperlukan untuk pemulihan. Memulihkan cadangan yang disalin berfungsi sama seperti pemulihan normal.
Status pemulihan
Database yang dipulihkan bertransisi melalui tiga status, yang dilacak oleh dua operasi yang berjalan lama.
CREATING: Spanner mulai memulihkan dengan membuat database baru dan memasang file dari cadangan. Selama statusCREATINGawal ini, database yang dipulihkan belum siap digunakan. Status ini biasanya selesai dalam waktu satu jam. Setelah statusCREATINGselesai, database Anda siap digunakan.Untuk melacak progres status ini, Anda dapat membuat kueri operasi pemulihan yang berjalan lama yang disediakan Spanner selama proses ini. Operasi ini menampilkan objek
RestoreDatabaseMetadata.Perhatikan peringatan berikut terkait status
CREATING:- Jika Anda memulihkan ke instance lain, operasi pemulihan akan menjadi milik instance yang berisi database yang dipulihkan, bukan instance yang berisi cadangan.
- Spanner tidak akan mengizinkan Anda menghapus cadangan saat sedang dipulihkan. Anda dapat menghapusnya setelah pemulihan selesai dan database memasuki status
READY. - Instance dapat memiliki maksimal sepuluh database dalam status
CREATINGkarena pemulihan dari cadangan. Anda tidak akan dapat memulihkan cadangan lain ke instance hingga salah satu dari sepuluh database yang dipulihkan bertransisi ke statusREADY_OPTIMIZINGatauREADY.
READY_OPTIMIZING: Setelah Spanner memasang cadangan, Spanner akan mulai menyalin data cadangan ke database baru sambil mengoptimalkan ukuran yang disimpan. Database Anda siap digunakan selama proses ini. Fase pemulihan ini biasanya memerlukan waktu beberapa jam untuk diselesaikan untuk database yang berukuran kurang dari 100 TB.Meskipun Anda dapat menggunakan database seperti biasa selama
READY_OPTIMIZING, peringatan berikut berlaku:- Latensi baca mungkin sedikit lebih tinggi dari biasanya.
- Metrik penyimpanan menampilkan ukuran database baru, bukan cadangan. Oleh karena itu, dengan transfer data yang masih berlangsung, metrik penyimpanan Spanner mungkin menampilkan hasil yang tidak mencerminkan ukuran total semua data Anda.
- Seperti halnya status
CREATING, Spanner tidak akan mengizinkan Anda menghapus cadangan yang terpasang.
Spanner menyediakan operasi pemulihan yang berjalan lama lainnya yang tersedia selama status ini, kali ini menampilkan objek metadata.
OptimizeRestoredDatabaseMetadataREADY: Setelah operasi salin dan optimalkan selesai, database akan bertransisi ke statusREADY. Database dipulihkan sepenuhnya, dan tidak lagi mereferensikan atau memerlukan cadangan.
Kontrol akses (IAM)
Peran spanner.restoreAdmin memberi Anda izin untuk memulihkan dari cadangan.
Untuk mengetahui informasi selengkapnya, lihat Kontrol akses dengan IAM.
Peran berikut juga memiliki akses ke operasi pemulihan Spanner:
spanner.admin: memiliki akses penuh untuk memulihkan. Peran ini memiliki akses lengkap ke semua resource Spanner.owner: memiliki akses penuh untuk memulihkan.editor: memiliki akses penuh untuk memulihkan.viewer: memiliki akses untuk melihat operasi pemulihan dan pemulihan. Peran ini tidak dapat membuat, memperbarui, menghapus, atau menyalin cadangan.
Harga
Tidak ada biaya untuk memulihkan dari cadangan.
Langkah berikutnya
- Untuk memulihkan database dari cadangan, lihat Memulihkan dari cadangan.