Service Extensions を使用すると、サポートされているアプリケーション ロードバランサでプラグインを使用したり、バックエンド サービスにコールアウトを送信して、処理パスにカスタム処理を挿入したりできます。トラフィック拡張は、リクエスト処理パスの最後に実行され、レスポンス処理パスの最初に実行されて、バックエンド サービスの選択に影響を与えることなくヘッダーとペイロードを変更します。このページでは、トラフィック拡張機能を構成する方法について説明します。
アプリケーション ロードバランサの拡張機能の概要については、Cloud Load Balancing の拡張機能の概要をご覧ください。
アプリケーション ロードバランサのトラフィック拡張機能は、次のリソースを指します。
- 関連付ける転送ルール
- バックエンドが
ext_procgRPC API を実行するプラグインまたはコールアウト バックエンド サービス
トラフィック拡張機能は、関連する拡張機能サービスを 1 つ以上のチェーンにグループ化します。同じ拡張機能チェーンでプラグインとコールアウトの両方を構成できます。各拡張機能チェーンは、Common Expression Language(CEL)一致条件を使用して、処理するトラフィックを選択します。ロードバランサは、各チェーンの一致条件に対してリクエストを順番に評価します。リクエストがチェーンで定義された条件に一致すると、チェーン内のすべての拡張機能がリクエストに対して動作します。特定のリクエストに一致するチェーンは 1 つだけです。
チェーン内の各拡張機能は、独自のサポート対象イベントのセットを持つことができます。拡張機能によってリクエストとレスポンスのコンテンツに加えられた変更は、チェーン内の残りの拡張機能に表示されます。レスポンス イベントをサポートするように構成された拡張機能の場合、拡張機能のシーケンスはレスポンス パスで逆になります。
トラフィック拡張機能は、関連付けるロードバランサの転送ルールを参照します。リソースを構成すると、ロードバランサは一致するリクエストの拡張サービスへの送信を開始します。
拡張機能に関連する上限については、割り当てと上限のページをご覧ください。
プラグインを使用して構成する
このセクションでは、プラグインを使用してトラフィック拡張機能を構成する方法について説明します。
特定のプラグインを参照するすべての拡張機能リソースは同じタイプである必要があります。拡張機能も同じロード バランシング スキームを使用する必要があります。Media CDN 拡張機能ですでに使用されているプラグインを使用して、Cloud Load Balancing 拡張機能を構成することはできません。
始める前に
トラフィック拡張機能プラグインをサポートするアプリケーション ロードバランサを作成して構成します。
たとえば、VM インスタンス グループのバックエンドを使用してグローバル外部アプリケーション ロードバランサを設定するをご覧ください。
サービスにテスト リクエストを送信する方法を設定します(curl の実行など)。内部ロードバランサを使用している場合は、テスト用のクライアント VM を作成します。
プラグインを使用してトラフィック拡張機能を構成する
次の例は、ホストが example.com と一致する場合にレスポンス ヘッダー hello: service-extensions を追加するプラグインを使用して、トラフィック拡張機能を構成する方法を示しています。
URL マップに
example.comと一致するものが存在するかどうかを確認します。クライアント VM の転送ルールに対して次の
curlコマンドを実行します。curl -D - -H "host: example.com" FORWARDING_RULE_IP
FORWARDING_RULE_IPは、転送ルールの IP アドレスに置き換えます。IP アドレスを確認するには、gcloud compute forwarding-rules describeコマンドを使用します。出力は次のようになります。
HTTP/1.1 200 OK ... content-length: 46 content-type: text/html via: 1.1 google
トラフィック拡張機能を構成します。
コンソール
Google Cloud コンソールで、[サービス拡張機能] ページに移動します。
[拡張機能を作成] をクリックします。
ウィザードが開き、初期設定の手順が表示されます。
プロダクトとして [ロード バランシング] を選択します。その後、[Continue] をクリックします。
サポートされているアプリケーション ロードバランサのリストが表示されます。
ロードバランサのタイプとして、グローバル外部アプリケーション ロードバランサまたはクロスリージョン内部アプリケーション ロードバランサのいずれかを選択します。その後、[続行] をクリックします。
拡張機能のタイプとして [トラフィック拡張機能] を選択し、[続行] をクリックします。
[拡張機能の作成] フォームを開くには、[続行] をクリックします。
[拡張機能の作成] フォームで、ページの上部に表示される前の選択内容が編集できないことに注意してください。
[基本] セクションで、次の操作を行います。
拡張機能の一意の名前を指定します。
名前は、先頭が英小文字で、その後に最大 62 文字の英小文字、数字、ハイフンで構成します。末尾をハイフンにすることはできません。
省略可: 1,024 文字以内で拡張機能の簡単な説明を入力します。
省略可: [ラベル] セクションで、[ラベルを追加] をクリックします。表示された行で、次の操作を行います。
- [キー] にキー名を入力します。
- [値] にキーの値を入力します。
Key-Value ペアをさらに追加するには、[ラベルを追加] をクリックします。最大 64 個の Key-Value ペアを追加できます。
ラベルの詳細については、プロジェクトのラベルを作成、更新するをご覧ください。
[転送ルール] で、拡張機能に関連付ける転送ルールを 1 つ以上選択します(例:
http-content-rule)。別の拡張機能にすでに関連付けられている転送ルールは選択できず、使用不可と表示されます。
拡張機能チェーンの場合は、一致したリクエストに対して実行する 1 つ以上の拡張機能チェーンを追加します。
拡張機能チェーンを追加するには、次の操作を行ってから [完了] をクリックします。
[新しい拡張チェーン] に一意の名前を指定します。
名前は RFC-1034 に準拠している必要があります。小文字(英字)、数字、ハイフンのみで構成し、最大文字数は 63 文字です。また、先頭の文字は英字に、末尾の文字は英字または数字にする必要があります。
拡張機能チェーンが実行されるリクエストを照合するには、[一致条件] に Common Expression Language(CEL)式(
request.host == "example.com"など)を指定します。CEL 式の詳細については、[構文のヘルプを表示] をクリックするか、CEL マッチャーの言語リファレンスをご覧ください。
一致したリクエストに対して実行する 1 つ以上の拡張機能を追加します。
拡張機能ごとに、[拡張機能] で次の操作を行い、[完了] をクリックします。
[Programmability type] で [Plugins] を選択します。
[拡張機能名] に、一意の名前を指定します。
名前は RFC-1034 に準拠している必要があります。小文字(英字)、数字、ハイフンのみで構成し、最大文字数は 63 文字です。また、先頭の文字は英字に、末尾の文字は英字または数字にする必要があります。
[プラグイン] で、同じプロダクトと拡張機能タイプ用に Service Extensions を使用して作成されたプラグインを選択します。
[イベント] で、拡張機能を呼び出す 1 つ以上の HTTP イベントタイプを選択します。
[転送ヘッダー] で、[ヘッダーを追加] をクリックし、拡張機能に転送する HTTP ヘッダー(クライアントまたはバックエンドから)を追加します。ヘッダーが指定されていない場合は、すべてのヘッダーが送信されます。
省略可: 拡張機能がタイムアウトまたは失敗し、リクエストまたはレスポンスの処理を続行する場合は、[Fail open] で [有効] を選択します。チェーン内の後続の拡張機能も実行されます。
デフォルトでは、[フェイルオープン] オプションは選択されていません。この場合、エラーが発生すると、リクエストまたはレスポンスの処理が停止します。レスポンス ヘッダーがダウンストリーム クライアントに配信されていない場合、一般的な HTTP
500ステータス コードがクライアントに返されます。レスポンス ヘッダーが配信されている場合、クライアントへの HTTP ストリームがリセットされます。セキュリティまたは完全性を優先する場合は、[フェイル オープン] を選択しないデフォルトのオプションが推奨されます。フェイルオープンを有効にすると、特に重要でないオペレーションで、可用性を優先する場合に役立ちます。
[拡張機能を作成] をクリックします。
gcloud
YAML ファイルでプラグインを定義し、転送ルール(
http-content-ruleなど)に関連付けます。cat >traffic-plugin.yaml <<EOF name: traffic-ext forwardingRules: - https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/forwardingRules/http-content-rule loadBalancingScheme: EXTERNAL_MANAGED extensionChains: - name: "chain1" matchCondition: celExpression: 'request.host == "example.com"' extensions: - name: 'ext1' service: projects/PROJECT_ID/locations/LOCATION/wasmPlugins/WASM_PLUGIN failOpen: false supportedEvents: - RESPONSE_HEADERS EOF次のように置き換えます。
PROJECT_ID: プロジェクト ID。REGION: 転送ルールのリージョン。値は、プラグインのロケーションに指定された値と一致している必要があります。LOCATION: プラグインのロケーション(globalまたはリージョン)。WASM_PLUGIN: プラグインの ID または完全修飾名。
トラフィック拡張機能をインポートします。次のサンプル値を使用して、
gcloud service-extensions lb-traffic-extensions importコマンドを使用します。gcloud service-extensions lb-traffic-extensions import traffic-ext \ --source=traffic-plugin.yaml \ --location=global
トラフィック拡張機能が作成された後、新しいプラグインがすべてのロケーションに分散されるまでに少し時間がかかります。プラグインはすべての地域に同時に配信されるわけではないため、地域によって時間が異なる場合があります。
トラフィック拡張機能が期待どおりに動作することを確認するには、同じ
curlコマンドを使用します。curl -D - -H "host: example.com" FORWARDING_RULE_IP
出力には
hello: service-extensionsレスポンス ヘッダーが含まれます。HTTP/1.1 200 OK ... content-length: 46 content-type: text/ hello: service-extensions via: 1.1 google拡張機能が
example.comトラフィックのみをターゲットにしていることを検証するには、hostヘッダーなしでcurlコマンドを繰り返します。curl -D - FORWARDING_RULE_IP
出力は次のようになります。
HTTP/1.1 200 OK ... content-length: 46 content-type: text/html via: 1.1 google
コールアウトを使用して、ユーザー管理サービスへのトラフィック拡張機能を構成する
このセクションでは、コールアウトを使用して、ユーザー管理のコールアウト バックエンド サービスにトラフィック拡張機能を構成する方法について説明します。
始める前に
コールアウト バックエンド サービスを構成するの説明に従って、必要なリソースを作成します。
コールアウトを使用してトラフィック拡張機能を構成する
次の例は、ホストが example.com と一致したときに呼び出すコールアウトを使用して、トラフィック拡張機能を構成する方法を示しています。callout-vm のトラフィック拡張機能サーバーは、一致するリクエストにレスポンス ヘッダー hello: service-extensions を追加します。
URL マップに
example.comと一致するものが存在するかどうかを確認します。クライアント VM の転送ルールに対して次の
curlコマンドを実行します。curl -D - -H "host: example.com" FORWARDING_RULE_IP
FORWARDING_RULE_IPは、転送ルールの IP アドレスに置き換えます。IP アドレスを確認するには、gcloud compute forwarding-rules describeコマンドを使用します。出力は次のようになります。
HTTP/1.1 200 OK ... content-length: 46 content-type: text/html via: 1.1 google Page served from: l7-ilb-backend-example-1c7t
トラフィック拡張機能を構成します。
コンソール
Google Cloud コンソールで、[サービス拡張機能] ページに移動します。
[拡張機能を作成] をクリックします。
ウィザードが開き、初期設定の手順が表示されます。
プロダクトとして [ロード バランシング] を選択します。その後、[Continue] をクリックします。
サポートされているアプリケーション ロードバランサのリストが表示されます。
ロードバランサのタイプを選択します。リージョン ロードバランサの場合は、リージョンも指定します。[続行] をクリックします。
拡張機能のタイプとして [トラフィック拡張機能] を選択し、[続行] をクリックします。
[拡張機能の作成] フォームを開くには、[続行] をクリックします。
[拡張機能の作成] フォームで、ページの上部に表示される前の選択内容が編集できないことに注意してください。
[基本] セクションで、次の操作を行います。
拡張機能の一意の名前を指定します。
名前は、先頭が英小文字で、その後に最大 62 文字の英小文字、数字、ハイフンで構成します。末尾をハイフンにすることはできません。
省略可: 1,024 文字以内で拡張機能の簡単な説明を入力します。
省略可: [ラベル] セクションで、[ラベルを追加] をクリックします。表示された行で、次の操作を行います。
- [キー] にキー名を入力します。
- [値] にキーの値を入力します。
Key-Value ペアをさらに追加するには、[ラベルを追加] をクリックします。最大 64 個の Key-Value ペアを追加できます。
ラベルの詳細については、プロジェクトのラベルを作成、更新するをご覧ください。
[転送ルール] で、拡張機能に関連付ける転送ルールを 1 つ以上選択します(例:
l7-ilb-forwarding-rule)。別の拡張機能にすでに関連付けられている転送ルールは選択できず、使用不可と表示されます。
拡張機能チェーンの場合は、一致したリクエストに対して実行する 1 つ以上の拡張機能チェーンを追加します。
拡張機能チェーンを追加するには、次の操作を行ってから [完了] をクリックします。
[Programmability type] で [Callouts] を選択します。
[新しい拡張機能チェーン名] に一意の名前を指定します。
名前は RFC-1034 に準拠している必要があります。小文字(英字)、数字、ハイフンのみで構成し、最大文字数は 63 文字です。また、先頭の文字は英字に、末尾の文字は英字または数字にする必要があります。
拡張機能チェーンが実行されるリクエストを照合するには、[一致条件] に Common Expression Language(CEL)式(
request.host == "example.com"など)を指定します。CEL 式の詳細については、[構文のヘルプを表示] をクリックするか、CEL マッチャーの言語リファレンスをご覧ください。
一致したリクエストに対して実行する 1 つ以上の拡張機能を追加します。
拡張機能ごとに、[拡張機能] で次の操作を行い、[完了] をクリックします。
[拡張機能名] に、一意の名前を指定します。
名前は RFC-1034 に準拠している必要があります。小文字(英字)、数字、ハイフンのみで構成し、最大文字数は 63 文字です。また、先頭の文字は英字に、末尾の文字は英字または数字にする必要があります。
[Authority] に、ロードバランサから拡張機能サービスに送信される gRPC リクエストの
authorityヘッダーを入力します。[バックエンド サービス] で、コールアウト バックエンド サービスを構成するの手順に沿って作成したバックエンド サービスを選択します。
[Timeout] に、ストリーム上のメッセージがタイムアウトするまでの時間(10 ~ 1, 000 ミリ秒)を指定します。
[イベント] で、拡張機能を呼び出す 1 つ以上の HTTP イベントタイプを選択します。
[転送ヘッダー] で、[ヘッダーを追加] をクリックし、拡張機能に転送する HTTP ヘッダー(クライアントまたはバックエンドから)を追加します。ヘッダーが指定されていない場合は、すべてのヘッダーが送信されます。
省略可: 拡張機能がタイムアウトまたは失敗し、リクエストまたはレスポンスの処理を続行する場合は、[Fail open] で [有効] を選択します。チェーン内の後続の拡張機能も実行されます。
デフォルトでは、[フェイルオープン] オプションは選択されていません。この場合、エラーが発生すると、リクエストまたはレスポンスの処理が停止します。レスポンス ヘッダーがダウンストリーム クライアントに配信されていない場合、一般的な HTTP
500ステータス コードがクライアントに返されます。レスポンス ヘッダーが配信されている場合、クライアントへの HTTP ストリームがリセットされます。セキュリティまたは完全性を優先する場合は、[フェイル オープン] を選択しないデフォルトのオプションが推奨されます。フェイルオープンを有効にすると、特に重要でないオペレーションで、可用性を優先する場合に役立ちます。
[メタデータ] で [メタデータを追加] をクリックし、提案されたサンプル値を指定します。[キー] に
keyを指定し、[値] にvalueを指定します。別の Key-Value ペアを追加するには、[メタデータを追加] をクリックします。[キー] に
frを指定し、[値] にforwarding_rule_idを指定します。[メタデータ] フィールドでは、ロードバランサから拡張機能サーバーに追加情報を渡すことができます。メタデータは
ProcessingRequestメッセージで送信され、protobuf.Structとしてエンコードされます。メタデータ内で指定された転送ルール ID と一致するテキストは、クライアント リクエストに関連付けられた転送ルールの完全修飾リソース URL に置き換えられます。メタデータの合計サイズは 1 KiB 未満である必要があります。メタデータのキーの合計数は 20 個未満にする必要があります。各キーの長さは 64 文字未満にする必要があります。各値の長さは 1,024 文字未満にする必要があります。すべての値は文字列にする必要があります。
[拡張機能を作成] をクリックします。
gcloud
YAML ファイルでコールアウトを定義し、転送ルールに関連付けます。提供されているサンプル値を使用します。
cat >traffic.yaml <<EOF name: traffic-ext forwardingRules: - https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-west1/forwardingRules/l7-ilb-forwarding-rule loadBalancingScheme: INTERNAL_MANAGED extensionChains: - name: "chain1" matchCondition: celExpression: 'request.host == "example.com"' extensions: - name: 'ext11' authority: ext11.com service: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-west1/backendServices/l7-ilb-callout-service failOpen: false timeout: 0.1s metadata: "key": "value" "fr": "forwarding_rule_id" supportedEvents: - RESPONSE_HEADERS EOFPROJECT_IDは、プロジェクト ID に置き換えます。拡張機能構成の
metadataフィールドを使用すると、ロードバランサから拡張機能サーバーに追加情報を渡すことができます。メタデータはProcessingRequestメッセージで送信され、protobuf.Structとしてエンコードされます。メタデータ内の指定された転送ルール ID と一致するテキストは、クライアント リクエストに関連付けられた転送ルールの完全修飾リソース URL に置き換えられます。metadataの合計サイズは 1 KiB 未満である必要があります。メタデータのキーの合計数は 16 未満にする必要があります。各キーの長さは 64 文字未満にする必要があります。各値の長さは 1,024 文字未満にする必要があります。すべての値は文字列にする必要があります。トラフィック拡張機能をインポートします。次のサンプル値を使用して、
gcloud service-extensions lb-traffic-extensions importコマンドを使用します。gcloud service-extensions lb-traffic-extensions import traffic-ext \ --source=traffic.yaml \ --location=us-west1
トラフィック拡張機能が想定どおりに機能することを確認します。同じ
curlコマンドを使用します。curl -D - -H "host: example.com" FORWARDING_RULE_IP
出力には
hello: service-extensionsレスポンス ヘッダーが含まれます。HTTP/1.1 200 OK ... content-length: 46 content-type: text/ hello: service-extensions via: 1.1 google Page served from: l7-ilb-backend-example-1c7t拡張機能が
example.comトラフィックのみをターゲットにしていることを検証するには、hostヘッダーなしでcurlコマンドを繰り返します。curl -D - FORWARDING_RULE_IP
出力は次のようになります。
HTTP/1.1 200 OK ... content-length: 46 content-type: text/html via: 1.1 google Page served from: l7-ilb-backend-example-1c7t
次のステップ
- Service Extensions プラグインの GitHub リポジトリで Rust、Go、C++ のプラグインの例とテストツールを参照する。
- コールアウト用の Service Extensions GitHub リポジトリで、
ext_procサーバーの Python と Go のサンプルを表示します。 - ルート拡張機能を構成する
- 拡張機能を管理する
- プラグインを管理する
- Google サービスへの拡張機能を構成する