我使用Openstack Heat和Juno发布,我遇到了问题。
我想使用AutoScalingGroup自动创建特定子网中的某些实例。 我的网络拓扑结构是一个具有多个子网的网络(每个层都在其自己的子网上)。
但Juno发布似乎无法实现,因为我们无法指定 OS :: Nova :: Server / networks中的子网参数。 该文档位于:http://docs.openstack.org/developer/heat/template_guide/openstack.html#OS::Nova::Server-prop-networks- * - 子网
我想知道是否有人在Juno中有这种限制的解决方法。
创建独立服务器时,可以指定OS :: Neutron :: Port,并引用子网。但我无法通过AutoScaling找到如何做到这一点。
非常感谢,
J.M。
编辑: 当前的堆栈。它仅适用于一个服务器,因为端口是在OS之外创建的:Heat :: AutoScalingGroup
resources:
instance_port:
type: OS::Neutron::Port
properties:
name: { get_param : portName }
network_id: { get_param: networkId }
fixed_ips:
- subnet_id: { get_param: subnetId }
security_groups: { get_param: securityGroups }
asg_group:
depends_on: [ instance_port ]
type: OS::Heat::AutoScalingGroup
properties:
...
resource:
type: OS::Nova::Server
properties:
name: { get_param: asgName }
....
networks:
# TODO assign direct IP to the right subnet by decommenting this line. Will be available in Liberty
#- subnet: { get_param: subnetId } /!\ doesn't work in Juno
- port: { get_resource : instance-port } /!\ Works only with one server
答案 0 :(得分:0)
解决方案是使用嵌套堆栈,其功能描述如下:http://docs.openstack.org/developer/heat/template_guide/composition.html#define-a-new-resource-type
您有一个带有端口和服务器的嵌套堆栈,并将此堆栈引用到主堆栈中。 示例: mainstack
resources:
asg_group:
type: OS::Heat::AutoScalingGroup
properties:
min_size: { get_param: min }
desired_capacity: { get_param: desired }
max_size: { get_param: max }
rolling_updates: {"max_batch_size": 1, "min_in_service": 2, "pause_time": 60}
resource:
type: "lib::AsgInstance"
properties:
appli: { get_param: appli }
嵌套堆栈:
resources:
instance-port:
type: OS::Neutron::Port
properties:
name: { get_param : portName }
network_id: { get_param: networkId }
fixed_ips:
- subnet_id: { get_param: subnetId }
security_groups: { get_param: securityGroups }
instance:
type: OS::Nova::Server
properties:
name: { get_param: instanceName }
key_name: { get_param: keyName }
image: { get_param: imageName }
flavor: { get_param: flavorName }
networks:
# TODO assign direct IP to the right subnet by decommenting this line. Will be available in Liberty
#- subnet: { get_param: subnetId }
- port: { get_resource : instance-port }
和环境文件:
resource_registry:
"lib::AsgInstance": lib/nestedstack.yaml