我正在寻找创建堆栈的最佳方法,包括许多单独的步骤。
我想在第一个模板中,只启动计算节点和网络配置。
在第二个模板中,我想创建存储节点并将它们附加到现有的计算节点。
您认为最好的方法是什么?
答案 0 :(得分:1)
以下是一种可行的方法。
1)为您的计算节点和网络配置定义第一个模板。但是在第一个模板中定义输出以显示计算节点ID。例如,如果您创建名为mynode1的OS :: Nova :: Server,则可以将其ID作为该模板的输出公开,如下所示:
outputs:
mynode1_id:
description: ID of mynode1
value: {getattr: [mynode1, id]}
使用第一个模板实例化一个热堆栈,比如mystack1,然后您可以按如下方式访问mynode1的ID:
heat output-show mystack1 mynode1_id
2)创建第二个存储模板,其中包含来自step1的计算节点的ID作为输入参数。例如:
parameters:
mynode1_id:
type: string
description: ID for mynode1
然后您可以在“资源:”部分中使用它,如下所示:
resources:
...
...
my_volume_attach:
type: OS::Cinder::VolumeAttachment
properties:
instance_uuid: {get_param: mynode1_id}
...
3)按如下方式调用第二个热量堆栈:
heat stack-create -f second-template.yaml -P mynode1_id=`heat output-show mystack1 mynode1_id` mystack2
答案 1 :(得分:0)
您可能还希望使用 depends_on 属性在资源之间定义依赖关系。 根据您的描述,似乎使用多个模板似乎不是正确的解决方案。
例如- 如果您希望在对象1,2之后创建对象3,4,则可以按如下方式定义模板:
heat_template_version: '2015-10-15'
parameters:
param1:
type: string
description: just an example of parameter
resources:
object1:
type: OS::Neutron::XXX
properties:
property: XXX
description: object1
object2:
type: OS::Neutron::XXX
properties:
property: XXX
description: object2
object3:
type: OS::Nova::XXX
properties:
property: XXX
description: object3
depends_on: object1
object4:
type: OS::Nova::XXX
properties:
property: XXX
description: object4
depends_on: object1