无法配置AutoScaling策略:EMR实例组不存在

时间:2017-11-07 19:43:27

标签: java amazon-web-services aws-sdk

我使用AmazonElasticMapReduceAsyncClientBuilder为实例组设置自动调节策略。

当我执行aws emr describe-cluster --cluster-id j-XXXXXXXXX时,我在自动缩放策略中遇到以下错误。 我有集群,Instance group&可用的IAM自动调节角色(EMR_AutoScaling_DefaultRole)

"Status": {   "State": "FAILED",   "StateChangeReason": {
    "Message": "Failed to provision the AutoScaling policy: EMR instance group doesn't exist: Failed to find Cluster j-3SGZHX7D2DM98.",
    "Code": "PROVISION_FAILURE"   }

我的putautoscale请求是

{   "clusterId": "j-3SGZHX7D2DM98",   "instanceGroupId": "ig-243GEE06N6JXS",   "autoScalingPolicy": {
    "constraints": {
      "minCapacity": 2,
      "maxCapacity": 10
    },
    "rules": [
      {
        "name": "Default-scale-out",
        "description": "Replicates the default scale-out rule in the console for YARN memory by adding one additional instance",
        "action": {
          "simpleScalingPolicyConfiguration": {
            "adjustmentType": "CHANGE_IN_CAPACITY",
            "scalingAdjustment": 1,
            "coolDown": 300
          }
        },
        "trigger": {
          "cloudWatchAlarmDefinition": {
            "comparisonOperator": "LESS_THAN",
            "evaluationPeriods": 1,
            "metricName": "YARNMemoryAvailablePercentage",
            "namespace": "AWS/ElasticMapReduce",
            "period": 200,
            "statistic": "AVERAGE",
            "threshold": 25.0,
            "unit": "PERCENT",
            "dimensions": [
              {
                "key": "JobFlowId",
                "value": "j-3SGZHX7D2DM98"
              }
            ]
          }
        }
      },
      {
        "name": "Default-scale-In",
        "description": "Replicates the default scale-out rule in the console for YARN memory by terminating  one  instance",
        "action": {
          "simpleScalingPolicyConfiguration": {
            "adjustmentType": "CHANGE_IN_CAPACITY",
            "scalingAdjustment": -2,
            "coolDown": 300
          }
        },
        "trigger": {
          "cloudWatchAlarmDefinition": {
            "comparisonOperator": "GREATER_THAN_OR_EQUAL",
            "evaluationPeriods": 1,
            "metricName": "YARNMemoryAvailablePercentage",
            "namespace": "AWS/ElasticMapReduce",
            "period": 300,
            "statistic": "AVERAGE",
            "threshold": 50.0,
            "unit": "PERCENT",
            "dimensions": [
              {
                "key": "JobFlowId",
                "value": "j-3SGZHX7D2DM98"
              }
            ]
          }
        }
      }
    ]   },   "progressListener": {
       },   "requestClientOptions": {
    "markers": {

    },
    "readLimit": 131073   } } 

未来对象的结果

{   ClusterId: j-3SGZHX7D2DM98,   InstanceGroupId: ig-243GEE06N6JXS,   AutoScalingPolicy: {
        Status: {
          State: PENDING,
          StateChangeReason: {
            Code: USER_REQUEST,
            Message: AutoScalingpolicymodifiedbyuserrequest
          }
        },
        Constraints: {
          MinCapacity: 2,
          MaxCapacity: 10
        },
        Rules: [
          {
            Name: Default-scale-out,
            Description: Replicatesthedefaultscale-outruleintheconsoleforYARNmemorybyaddingoneadditionalinstance,
            Action: {
              SimpleScalingPolicyConfiguration: {
                AdjustmentType: CHANGE_IN_CAPACITY,
                ScalingAdjustment: 1,
                CoolDown: 300
              }
            },
            Trigger: {
              CloudWatchAlarmDefinition: {
                ComparisonOperator: LESS_THAN,
                EvaluationPeriods: 1,
                MetricName: YARNMemoryAvailablePercentage,
                Namespace: AWS/ElasticMapReduce,
                Period: 200,
                Statistic: AVERAGE,
                Threshold: 25.0,
                Unit: PERCENT,
                Dimensions: [
                  {
                    Key: JobFlowId,
                    Value: j-3SGZHX7D2DM98
                  }
                ]
              }
            }
          },
          {
            Name: Default-scale-In,
            Description: Replicatesthedefaultscale-outruleintheconsoleforYARNmemorybyterminatingoneinstance,
            Action: {
              SimpleScalingPolicyConfiguration: {
                AdjustmentType: CHANGE_IN_CAPACITY,
                ScalingAdjustment: -2,
                CoolDown: 300
              }
            },
            Trigger: {
              CloudWatchAlarmDefinition: {
                ComparisonOperator: GREATER_THAN_OR_EQUAL,
                EvaluationPeriods: 1,
                MetricName: YARNMemoryAvailablePercentage,
                Namespace: AWS/ElasticMapReduce,
                Period: 300,
                Statistic: AVERAGE,
                Threshold: 50.0,
                Unit: PERCENT,
                Dimensions: [
                  {
                    Key: JobFlowId,
                    Value: j-3SGZHX7D2DM98
                  }
                ]
              }
            }
          }
        ]   } }

状态从挂起更改为失败 java代码

Future<PutAutoScalingPolicyResult> putAutoScalingPolicyResultFuture=emr.putAutoScalingPolicyAsync(scalingPolicyRequest);
PutAutoScalingPolicyResultputAutoScalingPolicyResult=emr.putAutoScalingPolicy(scalingPolicyRequest);

我做的相当于

aws emr put-auto-scaling-policy --cluster-id j-1EKZ3TYEVF1S2 --instance-group-id ig-3PLUZBA6WLS07 --auto-scaling-policy file://your/path/to/autoscaleconfig.json 

三江源

1 个答案:

答案 0 :(得分:2)

对我来说,这是因为群集没有标记&#34; visibleToAllUsers&#34 ;;我不得不发一个

aws emr modify-instance-attributes --cluster-id BLAH --visible-to-all-users

先改变。