Blaze 方案使用者可以設定 Firebase Realtime Database 進行自動備份,這項自助式功能可將資料庫應用程式資料和 Security Rules 備份到 Cloud Storage bucket,備份格式為 JSON。
設定
為節省儲存空間成本,我們預設啟用 Gzip 壓縮功能,您也可以選擇在 bucket 中啟用 30 天的生命週期政策,讓系統自動刪除超過 30 天的備份。
您可以在Firebase控制台中直接查看狀態和備份活動,也可以手動啟動備份作業。這項功能可讓您在執行任何程式碼變更前,擷取特定時間點的快照,或做為安全措施。
設定完成後,系統會為您建立新的 Cloud Storage 值區,並授予 Firebase WRITER 權限。您不應在這個 bucket 中儲存不希望 Firebase 存取的資料。Firebase 無法存取其他 Cloud Storage bucket 或 Google Cloud 的任何其他區域。
從備份還原
如要從備份還原 Firebase,請先從Cloud Storage將檔案下載到本機磁碟。方法是點選備份活動部分中的檔案名稱,或是透過 Cloud Storage 值區介面操作。如果檔案經過 Gzip 壓縮,請先解壓縮檔案。
匯入資料的方法有兩種:
選項 1:使用 Firebase 控制台。
依序前往「資料庫和儲存空間」>「即時資料庫」>「資料」分頁標籤。
按一下「Import JSON」,然後選取應用程式資料 JSON 檔案。
方法 2:從指令列發出 CURL 要求。
從 Firebase 擷取密鑰,您可以依序前往「資料庫和儲存空間」>「即時資料庫」>「設定」分頁取得密鑰。
在終端機中輸入下列內容,並將
DATABASE_NAME和SECRET欄位換成您自己的值:curl 'https://<DATABASE_NAME>.firebaseio.com/.json?auth=<SECRET>&print=silent' -X PUT -d @<DATABASE_NAME>.json
如果無法從超大型資料庫還原備份,請與 Firebase 支援團隊聯絡。
排程
系統每天會在特定時間執行資料庫備份,確保所有備份客戶都能享有最高可用性,並平均分配負載。無論您在當天是否手動備份,系統都會執行這項排程備份。
檔案命名
傳輸至 Cloud Storage 值區的檔案會加上時間戳記 (ISO 8601 標準),並採用下列命名慣例:
- 資料庫資料:
YYYY-MM-DDTHH:MM:SSZ_<DATABASE_NAME>_data.json - 資料庫規則:
YYYY-MM-DDTHH:MM:SSZ_<DATABASE_NAME>_rules.json
如果啟用 Gzip,檔案名稱會加上 .gz 後置字元。您可以使用 Cloud Storage 前置字串搜尋,輕鬆找出特定日期或時間的備份。
Gzip 壓縮
根據預設,我們會使用 Gzip 壓縮備份檔案,以節省儲存空間費用並縮短傳輸時間。壓縮後的檔案大小會因資料庫的資料特性而異,但一般資料庫可能會縮減至原始大小的 1/3,可節省儲存空間費用,並縮短備份的檔案上傳時間。
如要解壓縮 Gzipped JSON 檔案,請使用 gunzip 二進位檔發出指令列指令。這個二進位檔預設會隨 OS-X 和大多數 Linux 發行版本一起出貨。
gunzip <DATABASE_NAME>.json.gz # Will unzip to <DATABASE_NAME>.json
設定為期 30 天的儲存空間生命週期
我們提供簡單易用的設定切換選項,可為 Cloud Storage 值區啟用預設的 30 天物件生命週期政策。啟用後,儲存空間中的檔案會在 30 天後自動刪除。這有助於減少不必要的舊備份,節省儲存空間成本,並保持儲存空間目錄乾淨。如果將其他檔案放入自動備份值區,系統也會根據相同政策刪除這些檔案。
費用
Blaze 方案的專案可啟用備份功能,無須額外付費。不過,如果備份檔案放在 Cloud Storage 值區,則須按照標準費率付費。您可以啟用 Gzip 壓縮和儲存空間 30 天生命週期,降低儲存空間費用。