ダイレクト VPC 下り(外向き)を使用すると、Cloud Run から Redis インスタンスに接続できます。
設定
Google Cloud CLI をインストール済みで Redis インスタンスを作成済みの場合は、次の手順をスキップできます。
gcloud CLI をインストールして初期化します。
gcloud initクイックスタート ガイドの手順に沿って Redis インスタンスを作成します。Redis インスタンスのゾーン、IP アドレス、ポート番号をメモしておきます。
構成用に VPC ネットワークの下り(外向き)を準備する
Redis インスタンスに接続するには、Cloud Run サービスが Redis インスタンスの承認済み VPC ネットワークにアクセスできる必要があります。
このネットワークの名前を確認するには、次のコマンドを実行します。
gcloud redis instances describe INSTANCE_ID --region REGION --format "value(authorizedNetwork)"
ネットワーク名をメモしておきます。
サンプル アプリケーション
このサンプル HTTP サーバー アプリケーションは、Cloud Run サービスから Redis インスタンスへの接続を確立します。
選択したプログラミング言語のリポジトリのクローンを作成し、サンプルコードを含むフォルダに移動します。
Go
git clone https://github.com/GoogleCloudPlatform/golang-samples
cd golang-samples/memorystore/redis
Java
git clone https://github.com/GoogleCloudPlatform/java-docs-samples
cd java-docs-samples/memorystore/redis
Node.js
git clone https://github.com/GoogleCloudPlatform/nodejs-docs-samples
cd nodejs-docs-samples/memorystore/redis
Python
git clone https://github.com/GoogleCloudPlatform/python-docs-samples
cd python-docs-samples/memorystore/redis
このサンプル アプリケーションは、/ エンドポイントがアクセスされるたびに Redis カウンタをインクリメントします。
Go
このアプリケーションは、github.com/gomodule/redigo/redis クライアントを使用します。次のコマンドを実行してインストールします。
go get github.com/gomodule/redigo/redis@latest
アプリケーションの例:
Java
このアプリケーションは、Jetty 3.1 サーブレット ベースです。
Jedis ライブラリを使用します。
AppServletContextListener クラスは、長期間有効な Redis 接続プールを作成するために使用されます。
VisitCounterServlet クラスは、Redis カウンタをインクリメントするウェブ サーブレットです。
Node.js
このアプリケーションでは、redis モジュールを使用します。package.json ファイルのサンプルを次に示します。
サンプル アプリケーション コード:
Python
このアプリケーションでは、ウェブサービスに Flask を使用し、redis-py パッケージを使用して Redis インスタンスと通信します。
サンプル アプリケーション コード:
Cloud Run へのアプリケーションのデプロイ
アプリケーションをデプロイするには:
Dockerfileをソース ディレクトリにコピーします。cp cloud_run_deployment/Dockerfile .次のコマンドを実行して、Cloud Build を使用してコンテナ イメージをビルドします。
gcloud artifacts repositories create --location REPO_REGION --repository-format=docker REPO_ID gcloud builds submit --pack image=REPO_REGION-docker.pkg.dev/PROJECT_ID/REPO_ID/visit-counter:v1
次のコマンドを実行して、コンテナを Cloud Run にデプロイします。
gcloud run deploy \ --image REPO_REGION-docker.pkg.dev/PROJECT_ID/REPO_ID/visit-counter:v1 \ --allow-unauthenticated \ --region REGION \ --network NETWORK \ --subnet SUBNET \ --set-env-vars REDISHOST=REDIS_IP,REDISPORT=REDIS_PORT
ここで
REPO_REGIONは、リポジトリのリージョンです。REPO_IDは、アプリケーション イメージを含むリポジトリ名です。PROJECT_IDは、 Google Cloud プロジェクトの ID です。REGIONは Redis インスタンスが配置されているリージョンです。NETWORKは、Redis インスタンスがアタッチされている承認済み VPC ネットワークの名前です。SUBNETは、サブネットの名前です。サブネットは/26以上にする必要があります。VPC 下り(外向き)は IPv4 範囲(RFC 1918、RFC 6598、クラス E)をサポートします。REDIS_IPとREDIS_PORTは、Redis インスタンスの IP アドレスとポート番号です。
デプロイが正常に完了すると、コマンドラインに Cloud Run サービスの URL が表示されます。この URL をウェブブラウザでアクセス(または curl などのツールを使用)し、サービスがアクセスされるたびに Redis インスタンスのカウントが増加することを確認します。