11.17. 名前がホスト名およびパスと一致するリクエストのプールへの送信
Red Hat OpenStack Platform (RHOSP) Load-balancing サービス (octavia) を使用して、特定の条件に一致する Web クライアントリクエストをアプリケーションサーバーの別のプールにリダイレクトすることができます。ビジネスロジックの条件は、事前定義されたホスト名およびリクエストパスを照合しようとするレイヤー 7 (L7) ポリシーで実行されます。
以下の例では、ホスト名 api.example.com に一致するか、リクエストパスの先頭が /api であるすべての Web クライアントリクエストは、別のプール api_pool にリダイレクトされます。
前提条件
-
リスナー (
listener1) およびプール (pool1) を持つ HTTP ロードバランサー (lb1)。詳細は、Creating an HTTP load balancer with a health monitor を参照してください。
手順
Source コマンドで認証情報ファイルを読み込みます。
例
source ~/overcloudrc
$ source ~/overcloudrcCopy to Clipboard Copied! Toggle word wrap Toggle overflow ロードバランサー (
lb1) に 2 番目のプール (api_pool) を作成します。注記丸かっこ内の値は、この手順のコマンド例で使用されるサンプルの値です。これらのサンプル値を、実際のサイトに適した値に置き換えてください。
例
openstack loadbalancer pool create --name api_pool \ --lb-algorithm ROUND_ROBIN --loadbalancer lb1 --protocol HTTP
$ openstack loadbalancer pool create --name api_pool \ --lb-algorithm ROUND_ROBIN --loadbalancer lb1 --protocol HTTPCopy to Clipboard Copied! Toggle word wrap Toggle overflow プライベートサブネット (
private_subnet) のロードバランサーメンバー (192.0.2.10および192.0.2.11) をプール (static_pool) に追加します。例
この例では、バックエンドサーバー
192.0.2.10および192.0.2.11の名前は、それぞれmember1およびmember2です。openstack loadbalancer member create --name member1 --subnet-id \ private_subnet --address 192.0.2.10 --protocol-port 80 static_pool openstack loadbalancer member create --name member2 --subnet-id \ private_subnet --address 192.0.2.11 --protocol-port 80 static_pool
$ openstack loadbalancer member create --name member1 --subnet-id \ private_subnet --address 192.0.2.10 --protocol-port 80 static_pool $ openstack loadbalancer member create --name member2 --subnet-id \ private_subnet --address 192.0.2.11 --protocol-port 80 static_poolCopy to Clipboard Copied! Toggle word wrap Toggle overflow リスナー (
listener1) に L7 ポリシー (policy1) を作成します。ポリシーには、アクション (REDIRECT_TO_POOL) を追加し、プール (api_pool) を示す必要があります。例
openstack loadbalancer l7policy create --action REDIRECT_TO_POOL \ --redirect-pool api_pool --name policy1 listener1
$ openstack loadbalancer l7policy create --action REDIRECT_TO_POOL \ --redirect-pool api_pool --name policy1 listener1Copy to Clipboard Copied! Toggle word wrap Toggle overflow ホスト名
api.example.comにマッチする L7 ルールを、ポリシーに追加します。例
openstack loadbalancer l7rule create --compare-type EQUAL_TO \ --type HOST_NAME --value api.example.com policy1
$ openstack loadbalancer l7rule create --compare-type EQUAL_TO \ --type HOST_NAME --value api.example.com policy1Copy to Clipboard Copied! Toggle word wrap Toggle overflow リクエスパスの最初の
/apiにマッチする 2 番目の L7 ルールを、ポリシーに追加します。このルールは、最初のルールと論理的に AND で結合されます。
例
openstack loadbalancer l7rule create --compare-type STARTS_WITH \ --type PATH --value /api policy1
$ openstack loadbalancer l7rule create --compare-type STARTS_WITH \ --type PATH --value /api policy1Copy to Clipboard Copied! Toggle word wrap Toggle overflow
検証
-
openstack loadbalancer l7policy listコマンドを実行し、ポリシーpolicy1が存在することを確認します。 openstack loadbalancer l7rule list <l7policy>コマンドを実行し、policy1にcompare_typeがSTARTS_WITHおよびSTARTS_WITHであるルールが共に存在することを確認します。例
openstack loadbalancer l7rule list policy1 openstack loadbalancer l7rule list policy2
$ openstack loadbalancer l7rule list policy1 $ openstack loadbalancer l7rule list policy2Copy to Clipboard Copied! Toggle word wrap Toggle overflow