我正在寻找创建堆栈的最佳方法,包括许多单独的步骤。
我希望在第一个模板中,只获取计算节点和网络配置。
在第二个模板中,我想创建存储节点,并将它们附加到已经存在的计算节点。
你认为最好的方法是什么?
以下是一种可能的方法。
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) 使用步骤1中计算节点的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
您可能还想使用dependens_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