アプリケーションをローカルで開発してテストするには、Pub/Sub エミュレータを使用できます。これにより、本番環境の Pub/Sub サービスのローカル エミュレーションを可能にします。Pub/Sub エミュレータは Google Cloud CLI を使用して実行します。
エミュレータに対してアプリケーションを実行するには、まずエミュレータを起動し、環境変数を設定します。アプリケーションは、本番環境の Pub/Sub サービスではなくエミュレータと通信する必要があります。作成されたリソースとエミュレータに公開されたメッセージは、エミュレータ セッションの存続期間にわたって持続されます。
始める前に
Pub/Sub エミュレータを使用する前に、次の前提条件を満たす必要があります。
Python 開発環境を設定します。
JDK をインストールします。
Google Cloud CLI をインストールします。
Cloud クライアント ライブラリを使用してアプリケーションを構築します。
エミュレータをインストールする
コマンド プロンプトからエミュレータをインストールします。
gcloud components install pubsub-emulator gcloud components update
エミュレータをコンテナ イメージとしてインストールする
エミュレータをコンテナとしてインストールし、実行するには、gCloud Docker イメージをダウンロードしてインストールします。
エミュレータの開始
エミュレータを起動するには、コマンド プロンプトから pubsub start
を実行します。コマンドを実行する前に、PUBSUB_PROJECT_ID を有効なGoogle Cloud プロジェクト ID 文字列に置き換えます。Pub/Sub エミュレータはローカルで実行されるため、文字列は実際の Google Cloud プロジェクトを表す必要はありません。
gcloud beta emulators pubsub start --project=PUBSUB_PROJECT_ID [options]
フラグの全一覧については、gcloud beta emulators pubsub start
をご覧ください。
エミュレータの起動後、次のようなメッセージが表示されます。
... [pubsub] This is the Pub/Sub fake. [pubsub] Implementation may be incomplete or differ from the real system. ... [pubsub] INFO: Server started, listening on 8085
このメッセージは、Pub/Sub サーバーが、 Google Cloud エンドポイントではなく、ローカルマシン上のエミュレータ エンドポイントで実行されていることを示します。以下を含むすべてのオペレーションはローカルで行われます。
- トピックまたはサブスクリプションの作成
- パブリッシュ
- 登録
環境変数を設定する
エミュレータを起動した後、アプリケーションが Pub/Sub ではなくエミュレータに接続するように環境変数を設定する必要があります。これらの環境変数は、アプリケーションの実行に使用するマシンに設定します。
環境変数はエミュレータを開始するたびに設定する必要があります。環境変数は、動的に割り当てられるポート番号に依存しています。この番号は、エミュレータを再起動するたびに変わる可能性があります。
変数の自動設定
アプリケーションとエミュレータが同じマシン上で動作している場合は、次のようにして環境変数を自動的に設定できます。
Linux / macOS
コマンド代入を使用して env-init
を実行します。
$(gcloud beta emulators pubsub env-init)
Windows
env-init
からの出力を使用してバッチファイルを作成、実行します。
gcloud beta emulators pubsub env-init > set_vars.cmd && set_vars.cmd
これで、アプリケーションが Pub/Sub エミュレータに接続します。
変数の手動設定
アプリケーションとエミュレータが別々のマシン上で動作している場合は、次のようにして環境変数を手動で設定します。
env-init
コマンドを実行します。gcloud beta emulators pubsub env-init
アプリケーションを実行するマシンで、
env-init
コマンドの出力の指示に従ってPUBSUB_EMULATOR_HOST
環境変数と値を設定します。この設定により、アプリケーションがエミュレータに接続します。必要に応じて、エミュレータに使用するプロジェクトにPUBSUB_PROJECT_ID
環境変数を設定できます。Linux / macOS export PUBSUB_EMULATOR_HOST=[::1]:8432 export PUBSUB_PROJECT_ID=my-project-id
Windows set PUBSUB_EMULATOR_HOST=[::1]:8432 set PUBSUB_PROJECT_ID=my-project-id
これで、アプリケーションが Pub/Sub エミュレータに接続します。
注: Python App Engine スタンダード ローカル開発サーバーを使用している場合は、次のようにコマンドラインでこの環境変数を渡す必要があります。
dev_appserver.py app.yaml --env_var PUBSUB_EMULATOR_HOST=${PUBSUB_EMULATOR_HOST}
dev_appserver.py
は [PATH_TO_CLOUD_SDK]/google-cloud-sdk/bin/dev_appserver.py
に含まれています。
エミュレータの使用
エミュレータを使用するには、Cloud クライアント ライブラリを使用してアプリケーションを構築する必要があります。エミュレータでは、 Google Cloud コンソールまたは gcloud pubsub
コマンドはサポートされていません。
次の例では、エミュレータと Python Cloud クライアント ライブラリを使用してさまざまなオペレーションを実行するアプリケーションの使用を示しています。これらのオペレーションの例として、トピックの作成、メッセージのパブリッシュ、メッセージの読み取りの方法が含まれます。
エミュレータの環境変数を設定したマシンで、次の手順を行います。
Python リポジトリ全体のクローンを作成することによって、GitHub から Pub/Sub Python のサンプルを取得します。
クローン作成されたリポジトリで、
samples/snippets
ディレクトリに移動します。残りのステップをこのディレクトリで行います。サンプルの実行に必要な依存環境を
samples/snippets
ディレクトリからインストールします。pip install -r requirements.txt
トピックを作成します。
python publisher.py PUBSUB_PROJECT_ID create TOPIC_ID
(省略可)エミュレータで push サブスクリプションをテストするためのローカル push エンドポイントがない場合は、次の手順を実行して
http://[::1]:3000/messages
に作成します。- JSON サーバーをインストールします。
npm install -g json-server
- JSON サーバーを開始します。
ここで、json-server --port 3000 --watch db.json
db.json
には以下のスターター コードが含まれています。{ "messages": [] }
- 次のステップの PUSH_ENDPOINT のために、
http://[::1]:3000/messages
をメモしてください。
- JSON サーバーをインストールします。
トピックへのサブスクリプションを作成します。
pull サブスクリプションを作成します。
python subscriber.py PUBSUB_PROJECT_ID create TOPIC_ID SUBSCRIPTION_ID
push サブスクリプションを作成します。
python subscriber.py PUBSUB_PROJECT_ID create-push TOPIC_ID SUBSCRIPTION_ID \ PUSH_ENDPOINT
トピックにメッセージをパブリッシュします。
python publisher.py PUBSUB_PROJECT_ID publish TOPIC_ID
トピックにパブリッシュされているメッセージを読み取ります。
pull サブスクリプションからメッセージを取得します。
python subscriber.py PUBSUB_PROJECT_ID receive SUBSCRIPTION_ID
ローカル push エンドポイントに配信されたメッセージを確認します。たとえば、メッセージは次のようになります。
{ "messages": [ { "subscription": "projects/PUBSUB_PROJECT_ID/subscriptions/SUBSCRIPTION_ID", "message": { "data": "TWVzc2FnZSBudW1iZXIgMQ==", "messageId": "10", "attributes": {} }, "id": 1 }, ... ] }
環境変数へのアクセス
Java と C# 以外の言語では、環境変数の設定で説明されているように PUBSUB_EMULATOR_HOST
を設定すると、Pub/Sub クライアント ライブラリは、Pub/Sub ではなくローカル インスタンスで実行される API を自動的に呼び出します。
ただし C# と Java のクライアント ライブラリの場合には、エミュレータを使用するようにコードを変更する必要があります。
C#
このサンプルを試す前に、Pub/Sub クイックスタート: クライアント ライブラリの使用にある C# 向けの手順に従って設定を行ってください。 詳細については、Pub/Sub C# API のリファレンス ドキュメントをご覧ください。
Pub/Sub に対する認証を行うには、アプリケーションのデフォルト認証情報を設定します。詳細については、ローカル開発環境の認証を設定するをご覧ください。
Java
このサンプルを試す前に、Pub/Sub クイックスタート: クライアント ライブラリの使用にある Java 向けの手順に従って設定を行ってください。 詳細については、Pub/Sub Java API のリファレンス ドキュメントをご覧ください。
Pub/Sub に対する認証を行うには、アプリケーションのデフォルト認証情報を設定します。詳細については、ローカル開発環境の認証を設定するをご覧ください。
エミュレータの停止
エミュレータを停止するには、Ctrl+C キーを押します。
エミュレータを停止した後、次のコマンドを実行して PUBSUB_EMULATOR_HOST
環境変数を削除し、アプリケーションが Pub/Sub に接続するようにします。
unset PUBSUB_EMULATOR_HOST
set PUBSUB_EMULATOR_HOST=
エミュレータのコマンドライン引数
Cloud Pub/Sub エミュレータのコマンドライン引数の詳細については、gcloud beta emulators pubsub
をご覧ください。
サポートされている機能
エミュレータは、次の Pub/Sub 機能をサポートしています。
- メッセージの公開
- push サブスクリプションと pull サブスクリプションからのメッセージの受信
- メッセージの順序指定
- メッセージの再生
- デッドレター トピックへのメッセージの転送
- メッセージ配信のポリシーの再試行
- Avro のスキーマのサポート
既知の制限事項
UpdateTopic
とUpdateSnapshot
の RPC はサポートされていません。- IAM オペレーションはサポートされていません。
- 構成可能なメッセージ保持はサポートされていません。すべてのメッセージが無期限に保持されます。
- サブスクリプションの有効期限はサポートされていません。サブスクリプションの有効期限はありません。
- フィルタリングはサポートされていません。
- プロトコル バッファのスキーマ サポート。
- BigQuery サブスクリプションを作成することはできますが、BigQuery にメッセージは送信されません。
- 順序指定サブスクリプションのタイムスタンプまでシークすることはできません。
問題を報告するには、公開 Issue Tracker を送信してください。
次のステップ
- minikube で Pub/Sub エミュレータを使用する方法については、このブログ投稿をご覧ください。