Google Cloud Pub/Subとの連携¶
Google Cloud PlatformのプロダクトであるGoogle Cloud Pub/Subへ、通信モジュールからのデータを送信することを可能にします。
ヒント
Google Cloud Pub/Sub についての詳しい情報は 公式ドキュメント を参照してください。
設定の概要について¶
- Google Cloud Platformのサービスアカウントを作成し、秘密鍵を含むJSONをsakura.ioへ登録する必要があります
- sakura.ioからGoogle Cloud
Pub/SubへPublishする際に利用するTopicを作成しておく必要があります
- 上記のサービスアカウントに対して、このTopicへのPublishを行うための権限を付与する必要があります
- TopicへPublishされたデータを、お客様の作成した受け口に渡すためのSubscriptionを作成しておく必要があります
事前準備¶
認証用のJSON作成方法¶
Google Cloud Platform上でPublishを行う為に、サービスアカウントに紐付いたJSON形式のサービスアカウントキーを取得します。
Google Cloud Platformのコンソール画面より、「IAMと管理」→「サービスアカウント」をクリックします。
data:image/s3,"s3://crabby-images/7277b/7277b43e5d008bbe35b9480d0059188726ac3bd1" alt="gcp-account-1"
「サービスアカウントを作成」をクリックします。
data:image/s3,"s3://crabby-images/9bf94/9bf941e309586ef99d8fb63c288374ca1d4c9beb" alt="gcp-account-2"
「サービスアカウント名」に任意の文字列を入れ、作成を選択します。 (権限は後ほどTopicごとに設定するため、ここでは役割を指定する必要はありません。)
data:image/s3,"s3://crabby-images/e427d/e427d1c70d08eaa4fdb6eee7d2352141dc965bf6" alt="../../../../_images/gcp-account-3.png"
サービスアカウント作成後、「オプション」から「キーを作成」をクリックします。
data:image/s3,"s3://crabby-images/3bbdb/3bbdbee4e56004d6c4de5673c92925250a2800c2" alt="gcp-account-5"
「キーのタイプ」がJSON
であることを確認した上で「作成」を押し、JSON形式のサービスアカウントキーをダウンロードします。
data:image/s3,"s3://crabby-images/67069/67069899881d17fdcf8b5be304cc5ea6bc2ab92d" alt="gcp-account-6"
Topicの作成と権限の設定¶
sakura.ioからのメッセージを受けるためのTopicを作成します。 Google Cloud Pub/Subを開きます。
data:image/s3,"s3://crabby-images/6343e/6343e50f24fdac4ae3187651791f89572667219e" alt="gcp-pubsub-pub-1"
初めて開いた場合には、APIを有効化する必要があります。
data:image/s3,"s3://crabby-images/d8863/d886388dd584750feb1bf68d13b0d6a4bb057e66" alt="gcp-pubsub-pub-2"
Topic の作成を行います。
data:image/s3,"s3://crabby-images/6f07a/6f07ae25eac05704149081070c6cdc5b600c1145" alt="gcp-pubsub-pub-3"
Topic名は任意のものを入力し、作成します。
data:image/s3,"s3://crabby-images/16a5c/16a5c56454932b204a522f1b3a7a99d0500784a3" alt="gcp-pubsub-pub-4"
作成したTopicの権限設定を開きます。
data:image/s3,"s3://crabby-images/d42d2/d42d298629b7f6c7b96d47bb29cf98d2d9f2158c" alt="gcp-pubsub-pub-5"
メンバーとして、上で作成したサービスアカウント名を入力し、権限として
Pub/Sub パブリッシャー
を選択し、追加をクリックします。
data:image/s3,"s3://crabby-images/d8ede/d8eded8adbbcb483855e6178ee41ad620e176741" alt="gcp-pubsub-pub-6"
Subscriptionの作成¶
Topicから配信されたメッセージを外部から取得するためには Subscription を作成する必要があります。
注意事項
「サブスクライバ(Subscriber)」と「サブスクリプション(Subscription)」は混同しやすいので注意してください。 Subscriberはお客様側で用意していただくメッセージ受信機能、SubscriptionはTopicからSubscriberへメッセージを渡すためのGoogle Cloud Pub/Subにある機構です。
Topic作成後、Pub/Subの サブスクリプション から サブスクリプションを作成
をクリックします。
data:image/s3,"s3://crabby-images/21ef6/21ef6ce63ed6e730d392cc1e860cb971abe141fa" alt="../../../../_images/gcp-pubsub-subscription-1.png"
サブスクリプションID
に任意の文字列を入れ、 Cloud Pub/Sub トピック
は上で作成したトピック名を、 配信タイプ
は pull
を選択します。
(既にpush配信用のSubscriberを用意しているなら、配信タイプに push
を選択してください)
data:image/s3,"s3://crabby-images/60825/6082548a4f625a658777843c6a52477577cb67a6" alt="../../../../_images/gcp-pubsub-subscription-2.png"
画面下部の CREATE
をクリックするとSubscriptionが作成されます。
コントロールパネルの操作方法¶
Google Cloud Pub/Subの連携サービス追加¶
連携サービスの追加を行いたいプロジェクトの 詳細
ボタンをクリックします。
data:image/s3,"s3://crabby-images/72888/72888ed3b240ffa66cbe6aea3076ee2e14bc6f98" alt="プロジェクトの詳細ボタンをクリックして、プロジェクトの設定を開始します。"
プロジェクトの詳細ページ内の 連携サービス
をクリックします。連携サービス一覧表示に切り替わるので、右端の 連携サービス追加
をクリックします。
data:image/s3,"s3://crabby-images/9d0ad/9d0ada508a82fdb49ad0bf8e71840dbb4a50fb40" alt="連携サービスを追加"
連携サービスの選択画面でGoogle Cloud Pub/Sub Publisher
をクリックします。
data:image/s3,"s3://crabby-images/51a6a/51a6aa9fad271e4584110c611dcc0b0c41d4def6" alt="createawsiot1"
以下の項目を入力し、作成
ボタンをクリックします。
名前:任意のサービス連携名
Publish先のTopic名:上記で設定したGoogle Cloud Pub/Sub上のTopic名
サービスアカウントキー (JSON形式):Google Cloud Platform上で作成したJSON形式のサービスアカウントキー
data:image/s3,"s3://crabby-images/b437b/b437b3f21ab64b1a876976a62316c27bff4dee45" alt="createawsiot2"
注意事項
連携サービス作成、更新を行う際、正しい認証用JSONであるか、必要な権限が付与されているかの検証のために、以下のようなメッセージを送信します。
{"type": "keepalive", "datetime": "2017-12-12T08:46:12.158281Z"}