第 8 章 使用自定义角色和服务
Red Hat OpenStack Platform 通常由预定义角色中的节点组成,如 Controller 角色、Compute 角色和不同的存储角色类型的节点。这些默认角色各自包含一组您在核心 heat 模板集合中定义的服务。但是,一个一体化的 Red Hat OpenStack Platform 安装在一个包含所有 OpenStack 服务的单个节点上运行。/usr/share/openstack-tripleo-heat-templates/roles
目录中的 Standalone.yaml
角色文件是包含 all-in-one 安装中的所有服务的配置文件。您可以复制并修改 Standalone.yaml
角色文件,以启用和禁用安装中的服务。
Standalone.yaml
文件包含角色 Standalone
中的服务列表。使用以下示例了解此文件的语法:
在部署命令中包含此角色文件,以使用 Standalone 角色配置堆栈,其中包含您在角色文件的 ServicesDefault:
部分中包含的服务:
sudo openstack tripleo deploy --templates -r /usr/share/openstack-tripleo-heat-templates/roles/Standalone.yaml
[stack@all-in-one]$ sudo openstack tripleo deploy --templates -r /usr/share/openstack-tripleo-heat-templates/roles/Standalone.yaml
但是,在生产环境的多节点 Red Hat OpenStack Platform 环境中,您可以使用一个角色来分配包含 OpenStack 服务的一部分的角色,而不是在单个节点上包括所有服务。例如,默认的 Controller 角色包括管理、网络和高可用性服务,默认的 Compute 角色则包括计算服务。多节点环境中的默认角色文件是 /usr/share/openstack-tripleo-heat-templates/roles_data.yaml
文件。此文件定义以下角色类型:
- Controller
- Compute
- BlockStorage
- ObjectStorage
- CephStorage
使用以下示例了解多节点环境中的角色语法:
每次运行部署命令时,都必须包含角色文件。您可以使用部署命令中的 -r
参数覆盖此文件并使用自定义角色文件:
sudo openstack tripleo deploy --templates -r ~/templates/roles_data-custom.yaml
[stack@all-in-one]$ sudo openstack tripleo deploy --templates -r ~/templates/roles_data-custom.yaml
8.1. 在一体化 Red Hat OpenStack Platform 环境中启用和禁用服务 复制链接链接已复制到粘贴板!
/usr/share/openstack-tripleo-heat-templates/roles
目录中的 Standalone.yaml
角色文件是包含 all-in-one 安装中的所有服务的配置文件。您可以启用或禁用单个服务。
流程
要禁用服务,请创建新环境文件,并为您要禁用的服务包含值
OS::Heat::None
:- OS::TripleO::Services::<SERVICE>: OS::Heat::None
- OS::TripleO::Services::<SERVICE>: OS::Heat::None
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 在部署命令中包含此环境文件。
要启用服务,请创建新环境文件并从您要启用的服务中删除值
OS::Heat::None
:- OS::TripleO::Services::<SERVICE>:
- OS::TripleO::Services::<SERVICE>:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 在部署命令中包含此环境文件。