4.4. post-Configuration:自定义所有 Overcloud 角色
本文档的早期版本使用 OS::TripleO::Tasks::*PostConfig
资源来为每个角色提供安装后 hook。director 的 Heat 模板集合需要专用于使用这些 hook,这意味着您不应该将它们用于自定义用途。反之,使用下面概述的 OS::TripleO::NodeExtraConfigPost
hook。
当您完成 Overcloud 的创建但希望在初始创建或后续更新时,可以为所有角色添加额外的配置,会出现这种情况。在这种情况下,您可以使用以下后配置 hook:
- OS::TripleO::NodeExtraConfigPost
- 在核心 Puppet 配置后,应用到所有节点角色的额外配置。
在本例中,您首先创建一个基本的 heat 模板(/home/stack/templates/nameserver.yaml
),它将运行一个脚本,将每个节点的 resolv.conf
附加到变量名称服务器。
在本例中,Resources
部分包含以下内容:
- CustomExtraConfig
-
这定义了软件配置。在本例中,我们定义了 Bash
脚本
,Heat 将_NAMESERVER_IP_
替换为nameserver_ip
参数中存储的值。 - CustomExtraDeployments
这会执行软件配置,这是来自
CustomExtraConfig
资源的软件配置。注意以下几点:-
配置参数引用
CustomExtraConfig
资源,以便 Heat 了解要应用的配置。 -
servers
参数检索 Overcloud 节点的映射。此参数由父模板提供,是此 hook 模板中的强制要求。 -
actions
参数定义何时应用配置。在这种情况下,我们仅在创建 Overcloud 时应用配置。可能的操作包括CREATE
、UPDATE
、DELETE
、SUSPEND
和RESUME
。 -
input_values
包含一个名为deploy_identifier
的参数,它存储来自父模板中的DeployIdentifier
。此参数为每个部署更新的资源提供时间戳。这可确保在后续的 overcloud 更新中资源恢复。
-
配置参数引用
接下来,创建一个环境文件(/home/stack/templates/post_config.yaml
),将您的 heat 模板注册为 OS::TripleO::NodeExtraConfigPost:
资源类型。
resource_registry: OS::TripleO::NodeExtraConfigPost: /home/stack/templates/nameserver.yaml parameter_defaults: nameserver_ip: 192.168.1.1
resource_registry:
OS::TripleO::NodeExtraConfigPost: /home/stack/templates/nameserver.yaml
parameter_defaults:
nameserver_ip: 192.168.1.1
要应用配置,请在创建或更新 Overcloud 时将环境文件添加到堆栈中,以及其他环境文件。例如:
openstack overcloud deploy --templates \ ...
$ openstack overcloud deploy --templates \
...
-e /home/stack/templates/post_config.yaml \
...
这会在初始 Overcloud 创建或后续更新上完成核心配置后,将配置应用到所有节点。
您只能将 OS::TripleO::NodeExtraConfigPost
注册到一个 Heat 模板。后续使用会覆盖要使用的 Heat 模板。