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。
流程
以 stack 用户身份登录 undercloud,并提供
stackrc文件,以启用 director 命令行工具。示例
$ source ~/stackrc
创建自定义 YAML 环境文件。
示例
$ vi /home/stack/templates/my-neutron-environment.yaml
提示编排服务 (heat) 使用一组名为 template(模板) 的计划来安装和配置您的环境。您可以使用 自定义环境文件 自定义 overcloud 的各个方面,这是为 heat 模板提供自定义 的特殊模板。
在 YAML 环境文件中将
NeutronL3HA参数设置为true。这样可确保即使 director 没有被默认设置,也启用了 HA。parameter_defaults: NeutronL3HA: 'true'
设置调度 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限制为止。运行
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
其他资源
- Director 安装和使用指南中的环境文件
- Director 安装和使用指南中的 在 overcloud 创建中包含的环境文件