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


您可以使用 OpenShift (RHOSO)负载均衡服务(octavia)上的 Red Hat OpenStack Services 将与特定条件匹配的 Web 客户端请求重定向到备用应用服务器池。业务逻辑标准通过第 7 层(L7)策略来执行,该策略试图与预定义的主机名和请求路径匹配。

在本例中,任何与 hostname api.example.com 匹配的 Web 客户端请求,并且请求路径开头的 /api 会被重定向到备用池 api_pool

先决条件

  • 管理员已为您创建一个项目,并为您提供了一个 clouds.yaml 文件来访问云。
  • python-openstackclient 软件包驻留在您的工作站上。

    $ dnf list installed python-openstackclient
    Copy to Clipboard Toggle word wrap
  • HTTP load balancer (lb1) 有一个监听器 (listener1) 和一个池 (pool1)。如需更多信息,请参阅使用 运行状况监控器创建 HTTP 负载均衡器

流程

  1. 确认为您的云设置了系统 OS_CLOUD 变量:

    $ echo $OS_CLOUD
    my_cloud
    Copy to Clipboard Toggle word wrap

    如果需要,重置变量:

    $ export OS_CLOUD=my_other_cloud
    Copy to Clipboard Toggle word wrap

    作为替代方案,您可以在每次运行 openstack 命令时添加 --os-cloud <cloud_name > 选项指定云名称。

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

    注意

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

    Example

    $ openstack loadbalancer pool create --name api_pool \
    --lb-algorithm ROUND_ROBIN --loadbalancer lb1 --protocol HTTP
    Copy to Clipboard Toggle word wrap
  3. 在专用子网(private_subnet)上添加负载均衡器成员(192.0.2.10192.0.2.11)到池(static_pool)。

    示例

    在本例中,后端服务器 192.0.2.10192.0.2.11 分别命名为 member1member2

    $ 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
    Copy to Clipboard Toggle word wrap
  4. 在监听器 (listener1) 上创建一个 L7 策略 (policy1) 。策略必须包含操作(REDIRECT_TO_POOL),并指向池(api_pool)。

    Example

    $ openstack loadbalancer l7policy create --action REDIRECT_TO_POOL \
    --redirect-pool api_pool --name policy1 listener1
    Copy to Clipboard Toggle word wrap
  5. 在与 hostname api.example.com 匹配的策略中添加 L7 规则。

    Example

    $ openstack loadbalancer l7rule create --compare-type EQUAL_TO \
    --type HOST_NAME --value api.example.com policy1
    Copy to Clipboard Toggle word wrap
  6. 在策略中添加第二个 L7 规则,该规则与请求路径开头的 /api 匹配。

    此规则在逻辑上与第一条规则一致。

    Example

    $ openstack loadbalancer l7rule create --compare-type STARTS_WITH \
    --type PATH --value /api policy1
    Copy to Clipboard Toggle word wrap

验证

  1. 运行 openstack loadbalancer l7policy list 命令,并验证策略 policy1 是否存在。
  2. 运行 openstack loadbalancer l7rule list <l7policy> 命令,再验证两者都存在带有 EQUAL_TOSTARTS_WITHcompare_type 规则的 policy1

    Example

    $ openstack loadbalancer l7rule list policy1
    
    $ openstack loadbalancer l7rule list policy2
    Copy to Clipboard Toggle word wrap
返回顶部
Red Hat logoGithubredditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

Theme

© 2025 Red Hat