搜索

8.14. 根据主机名向特定池发送请求

download PDF

您可以使用 OpenShift (RHOSO)带有第 7 层(L7)策略的 Red Hat OpenStack Services on OpenShift (RHOSO)负载均衡服务(octavia)将包含 HTTP/1.1 主机名的请求重定向到不同的应用服务器池。

在本例中,任何包含以 .example.com 结尾的 HTTP/1.1 主机名的请求都会被重定向到备用池应用服务器 pool2

先决条件

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

    $ dnf list installed python-openstackclient
  • HTTP load balancer (lb1) 有一个监听器 (listener1) 和一个池 (pool1)。

    如需更多信息,请参阅使用 健康监控器创建 HTTP 负载均衡器

流程

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

    $ echo $OS_CLOUD
    my_cloud

    如果需要,重置变量:

    $ export OS_CLOUD=my_other_cloud

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

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

    注意

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

    Example

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

  3. 在监听器 (listener1) 上创建一个 L7 策略 (policy1) 。策略必须包含操作(REDIRECT_TO_POOL),并指向池(pool2)。

    Example

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

  4. 向策略添加一个 L7 规则,将任何使用 HTTP/1.1 主机名(www2.example.com)的请求发送到第二个池(pool2)。

    Example

    $ openstack loadbalancer l7rule create --compare-type ENDS_WITH \
    --type HOST_NAME --value .example.com policy1

验证

  1. 运行 openstack loadbalancer l7policy list 命令,并验证策略 policy1 是否存在。
  2. 运行 openstack loadbalancer l7rule list <l7policy> 命令,并验证策略存在一个带有 compare_typeEQUAL_TO 规则。

    Example

    $ openstack loadbalancer l7rule list policy1

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

© 2024 Red Hat, Inc.