10.12. 根据开始的路径将请求重定向到池


您可以使用 OpenShift (RHOSO)负载均衡服务(octavia)上的 Red Hat OpenStack Services 将 HTTP 请求重定向到备用服务器池。您可以定义第 7 层(L7)策略,以匹配请求的 URL 中的一个或多个启动路径。

在本例中,任何包含以 /js/images 开头的 URL 的请求都会被重定向到备用静态内容服务器池。

先决条件

  • 管理员已为您创建一个项目,并为您提供了一个 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)上创建第二个池(static_pool)。

    注意

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

    Example

    $ openstack loadbalancer pool create --name static_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)。

    Example

    在本例中,后端服务器 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),并指向池(static_pool)。

    Example

    $ openstack loadbalancer l7policy create --name policy1 \
    --action REDIRECT_TO_POOL --redirect-pool static_pool listener1
    Copy to Clipboard Toggle word wrap
  5. 在策略请求路径开始时查找 /js 的 L7 规则。

    Example

    $ openstack loadbalancer l7rule create --compare-type STARTS_WITH \
    --type PATH --value /js policy1
    Copy to Clipboard Toggle word wrap
  6. 创建一个 L7 策略(policy2),其中包含一个操作(REDIRECT_TO_POOL),并添加指向池的监听程序(listener1)。

    Example

    $ openstack loadbalancer l7policy create --name policy2 \
    --action REDIRECT_TO_POOL --redirect-pool static_pool listener1
    Copy to Clipboard Toggle word wrap
  7. 添加 L7 规则,该规则在到策略的请求路径开始时查找 /images

    Example

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

验证

  1. 运行 openstack loadbalancer l7policy list 命令,并验证存在策略 policy1policy2
  2. 运行 openstack loadbalancer l7rule list <l7policy > 命令,并验证每个相应策略存在带有 compare_typeSTARTS_WITH 的规则。

    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