##【はじめに】
- WEB系エンジニア歴6ヶ月目くらいなので記述などに間違いがあるかもしれないので優しく見守ってください。なので・・・間違いやご指摘があったら教えてください。
- Firebase RealtimeDBのBlazeプラン(有料)には自動バックアップ機能があるので有料プラン使ってる人には関係ない話です。
- 以下のサイトを参考に、自分の忘備録的な雰囲気の記事となっております。
- Cloud Functions for Firebase でジョブをスケジューリング(cron)する
- FirebaseのSparkプラン(無料枠)でRealtimeDBの自動バックアップを構築する
##【実行環境】
- Mac(OS:High Sierra)
##【前提条件】
-
Firebaseにプロジェクト作成済。
-
Firebaseで作成したプロジェクトがGCP上でも確認できていること。
(Firebaseで作成したら自動的に?GCP側にもプロジェクトが作成されるらしい) -
Cloud Build APIサービスが課金対象となっていること
⇒ サービスが課金対象となっているか確認する -
以下のツールがインストール、利用できること
1. git
2. Python2.7
3. Python pip
4. Google Cloud SDK
6. Firebase CLI
##【構築手順】
###1.プログラム取得・ディレクトリ構成確認
#####(1)とりあえず、gitHubからモジュール取得
※ 公式のプログラムではなく、個人的に手を加えたプログラムとなっているので注意!!
$ git clone https://github.com/Nunnally-Engr/firebase-rdb-backup-cron
#####(2)ディレクトリ変更
$ cd firebase-rdb-backup-cron
###2.実際のプログラムの中身の確認
-
今回確認&修正するプログラムは以下の通り。
-
.firebaserc
-
functions/index.js
-
functions/src/cron/backup.js
-
appengine/cron.yaml
-
.firebaserc
-
functions/index.js
-
App Engineから実際に呼び出される関数。Functionsをdeployしたら、この関数名が表示される。
-
ここでは〜.topic内の文字列("data-bakup-all")とappengine/cron.yamlのurl部分("/publish/data-bakup-all")がポイント!!
-
functions/src/cron/backup.js
-
上記で説明したindex.jsから呼び出している関数。実際に、RealtimeDBを参照して、Admin Cloud Storage API経由でGCPのバケット機能を使ってBackup用のjsonファイルを作成する処理となる。(ソースの内容は割愛)
-
appengine/cron.yaml
-
今回は、24時間ごとにBackupを取る設定している。
追加でスケジューリングの設定する場合はこのファイルで設定する。
※ 詳細はGoogle公式のcron.yaml リファレンス:schedule の書式に記載されている。
###3.Firebase CloudFunctionsにdeployする
(1)Firebaseにログインする
$ firebase login
(2)Firebaseで使用しているプロジェクトの確認(※省略可)
$ firebase list
(3)使用するプロジェクトの選択(※選択されている場合は省略可)
$ firebase use [プロジェクトID]
(4)ディレクトリ移動
$ cd functions/
(5)deploy実行
$ firebase deploy --only functions
【参考】もしくは・・・特定のFunctionのみdeploy
$ firebase deploy --only functions:dataBackupAll
(6)deployできていることをFirebaseのFunctions上で確認
###4.GCP のApp EngineにCronジョブをdeployする
(1)GCPで使用しているプロジェクトの確認(※省略可)
$ gcloud projects list
(2)使用するプロジェクトの選択(※選択されている場合は省略可)
$ gcloud config set project [プロジェクトID]
(3)『appengine』ディレクトリへ移動
$ cd appengine/
(4)pipを使って必要なパッケージをインストールする
$ pip install -t lib -r requirements.txt
(5)App Engineアプリを作成する(※作成されている場合は省略可)
$ gcloud app create
(6)deploy実行
$ gcloud app deploy app.yaml \cron.yaml
(7)deployできていることをGCPのApp Engine上で確認
##【動作確認】
###1.App EngineのCronジョブで「今すぐ実行」する
###2.Firebaseのfunctionsのログに、「stream:successfully finished.」と表示されていれば処理は正常終了となる。
※ 実行して、jsonファイルが作成できるまで少し時間がかかることもあるので必ずログを確認すること。
###3.さらに、FirebaseのStorageにjsonファイルができていたら問題なし。
##【その他メモ・・・】
- Firebase側のプロジェクトを見たら、従量課金になっていたので無料枠に戻したら"gcloud app deploy" ができなくなった。
⇒ Cloud Build APIサービスを一度無効にして、再度有効に戻したらdeployができた。
##【終わりに】
- GCPの操作とか仕組みや癖?を知っていたら数分でできるのだろうけど、私は結構苦労しました💦
ただ、一度作ると簡単に思えてきたので個人プロダクトとかには有効かと。
お金があるならもちろん有料プランをおすすめ(笑)
次は自動で削除とかそっち方面のものを作ってみようかと考えてます。