Назад | Перейти на главную страницу

UpdatePolicy в группе автоматического масштабирования не удалось обновить экземпляры

Я использовал следующие настройки в CloudFormation для создания группы автомасштабирования:

"myautoscalinggroup": {
  "Type": "AWS::AutoScaling::AutoScalingGroup",
  "UpdatePolicy" : {
    "AutoScalingRollingUpdate" : {
     "MinInstancesInService" : "1",
     "MaxBatchSize" : "2",
     "WaitOnResourceSignals" : "true",
     "PauseTime" : "PT5M"
    }
  },
  "Properties": {
    "AvailabilityZones": [
      "ap-southeast-2b",
      "ap-southeast-2a"
    ],
    "Cooldown": "300",
    "DesiredCapacity": { "Ref" : "InstanceCount"},
    "HealthCheckGracePeriod": "300",
    "HealthCheckType": "EC2",
    "MaxSize": "5",
    "MinSize": "1",
    "VPCZoneIdentifier": { "Ref" : "WebServerSubnets" },
    "LaunchConfigurationName": {
      "Ref": "mylaunchconfiguration"
    },
    "LoadBalancerNames": [
      {
        "Ref": "myloadbalancer"
      }
    ],
    "TerminationPolicies": [
      "Default"
    ]
  }
},
"mylaunchconfiguration": {
  "Type": "AWS::AutoScaling::LaunchConfiguration",
  "Metadata" : {
    "Comment": "Get web page",
    "AWS::CloudFormation::Init" : {
      "config" : {
        "packages" : {
          "yum" : {
            "httpd" : []
          }
        },
        "sources" : { 
          "/var/www/html" :  "address to web-site contents"
        },
        "services" : {
          "sysvinit" : {
            "httpd"    : { "enabled" : "true", "ensureRunning" : "true" }
          }
        }
      }
    }
  },
  "Properties": {
    "ImageId": "ami-fd9cecc7",
    "InstanceType": "t2.micro",
    "UserData" : { "Fn::Base64" : { "Fn::Join" : ["", [
      "#!/bin/bash -xe\n",
      "yum update -y aws-cfn-bootstrap\n",
      "/opt/aws/bin/cfn-init -v ",
         "         --stack ", { "Ref" : "AWS::StackName" },
         "         --resource mylaunchconfiguration ",
         "         --region ", { "Ref" : "AWS::Region" }, "\n",

      "/opt/aws/bin/cfn-signal -e $? ",
         "         --stack ", { "Ref" : "AWS::StackName" },
         "         --resource myautoscalinggroup ",
         "         --region ", { "Ref" : "AWS::Region" }, "\n"

    ]]}},
    "KeyName": "myKey",
    "SecurityGroups": [{ "Ref" : "mySecurityGroup" }],
    "BlockDeviceMappings": [
      {
        "DeviceName": "/dev/xvda",
        "Ebs": {
          "VolumeSize": 8
        }
      }
    ]
  }
}

Но политика обновления не может обновлять экземпляры, когда я обновляю стек с новой конфигурацией запуска. Но когда я завершаю экземпляры вручную, AutoScalingGroup срабатывает и запускает новые экземпляры с обновленной конфигурацией LaunchConfiguration. Есть идеи, как заставить работать политику обновления?

Спасибо