19.6. 在 RHOSP 网络服务节点上启用第 3 层高可用性(HA)

在安装过程中,当您至少有两个 RHOSP Controller 且不使用分布式虚拟路由(DVR)时,Red Hat OpenStack Platform (RHOSP) director 会为虚拟路由器启用高可用性(HA)。使用 RHOSP Orchestration 服务(heat)参数 max_l3_agents_per_router,您可以设置调度 HA 路由器的最大 RHOSP 网络服务层 3 (L3)代理数。

先决条件

  • 您的 RHOSP 部署不使用 DVR。
  • 您至少部署了两个 RHOSP Controller。

流程

  1. 以 stack 用户身份登录 undercloud,并提供 stackrc 文件,以启用 director 命令行工具。

    示例

    $ source ~/stackrc

  2. 创建自定义 YAML 环境文件。

    示例

    $ vi /home/stack/templates/my-neutron-environment.yaml

    提示

    编排服务 (heat) 使用一组名为 template(模板) 的计划来安装和配置您的环境。您可以使用 自定义环境文件 自定义 overcloud 的各个方面,这是为 heat 模板提供自定义 的特殊模板。

  3. 在 YAML 环境文件中将 NeutronL3HA 参数设置为 true。这样可确保即使 director 没有被默认设置,也启用了 HA。

    parameter_defaults:
      NeutronL3HA: 'true'
  4. 设置调度 HA 路由器的最大 L3 代理数。

    max_l3_agents_per_router 参数设置为部署中最少和网络节点总数之间的值。(零值表示路由器在每个代理上调度。)

    示例

    parameter_defaults:
      NeutronL3HA: 'true'
      ControllerExtraConfig:
        neutron::server::max_l3_agents_per_router: 2

    在本例中,如果您部署四个网络服务节点,则只有两个 L3 代理来保护每个 HA 虚拟路由器:一个活跃,一个备用。

    如果将 max_l3_agents_per_router 的值设置为大于可用网络节点数量,您可以通过添加新的 L3 代理来扩展待机路由器的数量。对于您部署的每个新 L3 代理节点,网络服务会调度虚拟路由器的额外待机版本,直到达到 max_l3_agents_per_router 限制为止。

  5. 运行 openstack overcloud deploy 命令,并包含核心 heat 模板、环境文件和这个新的自定义环境文件。

    重要

    环境文件的顺序非常重要,因为后续环境文件中定义的参数和资源更为优先。

    示例

    $ openstack overcloud deploy --templates \
    -e [your-environment-files] \
    -e /usr/share/openstack-tripleo-heat-templates/environments/services/my-neutron-environment.yaml

    注意

    NeutronL3HA 设置为 true 时,所有创建的虚拟路由器都默认为 HA 路由器。当您创建路由器时,您可以通过在 openstack router create 命令中包含 --no-ha 选项来覆盖 HA 选项:

    # openstack router create --no-ha

其他资源