Juno中子网上的Openstack加热AutoScalingGroup

时间:2016-02-15 16:57:02

标签: autoscaling openstack-heat

我使用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

1 个答案:

答案 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