10.17. 将请求发送到名称与主机名和路径匹配的池


您可以使用 Red Hat OpenStack Platform (RHOSP)负载均衡服务(octavia)将与特定条件匹配的 web 客户端请求重定向到另一个应用程序服务器池。业务逻辑标准通过第 7 层(L7)策略来执行,该政策会尝试与预定义的主机名和请求路径匹配。

在本例中,任何与 hostname api.example.com 匹配的 web 客户端请求,并在请求路径开始时具有 /api 重定向到另一个池 api_pool

前提条件

流程

  1. 提供您的凭据文件。

    Example

    $ source ~/overcloudrc

  2. 在负载平衡器(lb1)上创建第二个池(api_pool)。

    注意

    括号中的值是本流程中示例命令中使用的示例值。将这些示例值替换为适合您的站点的值。

    Example

    $ openstack loadbalancer pool create --lb-algorithm ROUND_ROBIN --loadbalancer lb1 --name api_pool --protocol HTTP

  3. 将专用子网(private_subnet)上的负载平衡器成员( 192.0.2.10 和 192.0.2.11)添加到池(static_pool):

    Example

    $ openstack loadbalancer member create --subnet-id private_subnet --address 192.0.2.10 --protocol-port 80 static_pool
    $ openstack loadbalancer member create --subnet-id private_subnet --address 192.0.2.11 --protocol-port 80 static_pool

  4. 在监听器(侦听器1)上创建 L7 策略(policy1)。策略必须包含操作(REDIRECT_TO_POOL),并指向池(api_pool)。

    Example

    $ openstack loadbalancer l7policy create --action REDIRECT_TO_POOL --redirect-pool api_pool --name policy1 listener1

  5. 在与 hostname api.example.com 匹配的策略中添加 L7 规则。

    Example

    $ openstack loadbalancer l7rule create --compare-type EQUAL_TO --type HOST_NAME --value api.example.com policy1

  6. 将第二个 L7 规则添加到与请求路径开头的 /api 匹配的策略。

    该规则通过第一个规则进行逻辑化。

    Example

    $ openstack loadbalancer l7rule create --compare-type STARTS_WITH --type PATH --value /api policy1

验证

  1. 运行 openstack loadbalancer l7policy list 命令,再验证策略 policy1 是否存在。
  2. 运行 openstack loadbalancer l7rule list <l7policy& gt; 命令,并验证规则及 compare_typeEQUAL_TOSTARTS_WITH,分别适用于 policy1

    Example

    $ openstack loadbalancer l7rule list policy1
    $ openstack loadbalancer l7rule list policy2

其他资源

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.