[A-00185]Google CloudのStorage Transfer Serviceを使ってみる
Google Cloudが提供するMFT(Managed File Transfer)サービスであるStorage Transfer Serviceを使ってみたいと思います。
・シンプルなイベントドリブン方式のファイル転送ジョブを作成する。
アーキテクチャは下記の通りです。プロジェクトAから別プロジェクトのバケットにファイルを転送します。イベントドリブン方式を採用するのでプロジェクトAのバケットにファイルが作成(object.finalize)されたら自動でプロジェクトBのバケットに転送してくれます。
data:image/s3,"s3://crabby-images/99fb9/99fb9536cbabedb7d2e8feae97360ce7159bd61e" alt=""
このセクションではgcloudコマンドとコンソールを利用して上記のシステムを作ってみます。
まずプロジェクトA(自分で好きな名前のプロジェクトを作成してください)にインプット用のバケットを作成します。同様にプロジェクトBにもアウトプット用バケットを作成します。
gsutil mb -p <project-a-name> -c standard -l asia-northeast1 gs://sts-test-input-bkt
gsutil mb -p <project-b-name> -c standard -l asia-northeast1 gs://sts-test-output-bkt
次にプロジェクトAのバケットにNotificationという機能を実装します。Notificationは下記のコマンドで作成できます。同時にPub/Subトピックも作成しますので適当な名前をつけてください。
gcloud storage buckets notifications create gs://sts-test-input-bkt --topic=stsnotif-topic
次に上記のコマンドで作成したトピックに対応するサブスクリプションを作成します。
gcloud pubsub subscriptions create stsnotif-sub --topic=stsnotif-topic --ack-deadline=300
Google Cloud Consoleから確認するとちゃんとできていることがわかります。
data:image/s3,"s3://crabby-images/404c2/404c2356567aca8590bc5e82baadd2795547f180" alt=""
次にGoogle CloudコンソールからStorage Transfer ServiceのJobを作成します。
data:image/s3,"s3://crabby-images/fa91f/fa91f0ab6c7d53587244aadc046c7622a846fa85" alt=""
転送元と転送先はどちらもCloudStorageなので下記の通りに選択します。
次にイベントドリブン方式を選択して[次のステップ]ボタンを押下します。
data:image/s3,"s3://crabby-images/4268e/4268e94cb539cd24ad102c913c9ced1d9dbdf988" alt=""
次に転送元のバケットとサブスクリプションを指定します。
<入力前>
data:image/s3,"s3://crabby-images/7a2e0/7a2e08783d624e2aa35ee61b212f7ce71e0292bc" alt=""
<入力後>
data:image/s3,"s3://crabby-images/dc587/dc5875fd56781f5daf72cda4c9ab5b797b611e6a" alt=""
[次のステップ]ボタンを押下して下記の画面になります。同じように転送先バケットを設定します。
data:image/s3,"s3://crabby-images/06907/069076ce97134e9a63540251a9f245582934fb59" alt=""
次の画面ではジョブの開始時刻を指定できますが、特にトリガーとなるイベントは無いため、即時開始を選択します。
data:image/s3,"s3://crabby-images/b4833/b4833e1a9f49266d4a23a4c2e2b137559df1b455" alt=""
次の画面では細かいオプションを指定できます。下記のキャプチャの通り設定して[作成]ボタンを押下し、ジョブを作成してください。
data:image/s3,"s3://crabby-images/513d0/513d0f7b80758cd238e836fe1c5f300b8e46d71b" alt=""
data:image/s3,"s3://crabby-images/35a97/35a97689765dc6b0fcf9a0f939b25bb71e3fa98e" alt=""
作成ボタンを押下したら下記の通りジョブが作成されます。
data:image/s3,"s3://crabby-images/eee41/eee41ca30ab28bd3c87f2f9926e38eae81ab5eb3" alt=""
data:image/s3,"s3://crabby-images/afc69/afc696da14efd98c3a0deae216ac44dc4acd48ec" alt=""
<注意>
作成ボタンを押下したらエラーが出た場合、Storage Transfer Serviceのサービスアカウントに権限がなくてエラーが発生しています。その場合は下記の対応を行います。Pub/Sub Subscriberロールの権限がない場合が多いです。
<サービスアカウントの調べ方>
GET https://storagetransfer.googleapis.com/v1/googleServiceAccounts/{projectId}
<ロール付与の方法>
gcloud projects add-iam-policy-binding <project-id> --member='serviceAccount:project-<PROJECT_NUMBER>@storage-transfer-service.iam.gserviceaccount.com' --role='roles/pubsub.subscriber'
上記の作業が完了したらバケットにファイルを置いてみてください。転送されるはずです。
data:image/s3,"s3://crabby-images/a96b3/a96b3a56635b0b1e66decd42c0a898daecb69bde" alt=""
data:image/s3,"s3://crabby-images/26703/267036f8f3bd25b96e4716bc2c4888b293c6b296" alt=""
data:image/s3,"s3://crabby-images/bfab2/bfab2c5122cebbcd751111c617a296175333321a" alt=""
・terraformからStorage Transfer Jobを作成してみる
・Appendix
公式ドキュメントはこちら
https://cloud.google.com/storage-transfer/docs/event-driven-transfers?hl=ja#gcloud-cli
コメントを残す