Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Socket
Sign inDemoInstall

@aws-cdk/aws-applicationautoscaling

Package Overview
Dependencies
Maintainers
5
Versions
288
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-cdk/aws-applicationautoscaling - npm Package Compare versions

Comparing version 0.33.0 to 0.34.0

7

lib/step-scaling-action.d.ts

@@ -1,2 +0,1 @@

import cloudwatch = require('@aws-cdk/aws-cloudwatch');
import cdk = require('@aws-cdk/cdk');

@@ -62,3 +61,3 @@ import { IScalableTarget } from './scalable-target';

*/
export declare class StepScalingAction extends cdk.Construct implements cloudwatch.IAlarmAction {
export declare class StepScalingAction extends cdk.Construct {
/**

@@ -68,6 +67,2 @@ * ARN of the scaling policy

readonly scalingPolicyArn: string;
/**
* ARN when this scaling policy is used as an Alarm action
*/
readonly alarmActionArn: string;
private readonly adjustments;

@@ -74,0 +69,0 @@ constructor(scope: cdk.Construct, id: string, props: StepScalingActionProps);

3

lib/step-scaling-action.js

@@ -34,3 +34,2 @@ "use strict";

this.scalingPolicyArn = resource.scalingPolicyArn;
this.alarmActionArn = this.scalingPolicyArn;
}

@@ -93,2 +92,2 @@ /**

})(MetricAggregationType = exports.MetricAggregationType || (exports.MetricAggregationType = {}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step-scaling-action.js","sourceRoot":"","sources":["step-scaling-action.ts"],"names":[],"mappings":";;AACA,oCAAqC;AACrC,yFAAsE;AA0DtE;;;;;;;;GAQG;AACH,MAAa,iBAAkB,SAAQ,GAAG,CAAC,SAAS;IAalD,YAAY,KAAoB,EAAE,EAAU,EAAE,KAA6B;QACzE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAHF,gBAAW,GAAG,IAAI,KAAK,EAA2C,CAAC;QAKlF,yFAAyF;QACzF,6DAA6D;QAC7D,wHAAwH;QACxH,MAAM,QAAQ,GAAG,IAAI,mDAAgB,CAAC,IAAI,EAAE,UAAU,EAAE;YACtD,UAAU,EAAE,KAAK,CAAC,UAAU,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ;YAClD,UAAU,EAAE,aAAa;YACzB,eAAe,EAAE,KAAK,CAAC,aAAa,CAAC,gBAAgB;YACrD,8BAA8B,EAAE;gBAC9B,cAAc,EAAE,KAAK,CAAC,cAAc;gBACpC,QAAQ,EAAE,KAAK,CAAC,WAAW;gBAC3B,sBAAsB,EAAE,KAAK,CAAC,sBAAsB;gBACpD,qBAAqB,EAAE,KAAK,CAAC,qBAAqB;gBAClD,eAAe,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC;aACI;SAC7D,CAAC,CAAC;QAEH,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC,gBAAgB,CAAC;QAClD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,gBAAgB,CAAC;IAC9C,CAAC;IAED;;OAEG;IACI,aAAa,CAAC,UAA0B;QAC7C,IAAI,UAAU,CAAC,UAAU,KAAK,SAAS,IAAI,UAAU,CAAC,UAAU,KAAK,SAAS,EAAE;YAC9E,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;SACzE;QACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YACpB,wBAAwB,EAAE,UAAU,CAAC,UAAU;YAC/C,wBAAwB,EAAE,UAAU,CAAC,UAAU;YAC/C,iBAAiB,EAAE,UAAU,CAAC,UAAU;SACzC,CAAC,CAAC;IACL,CAAC;CACF;AAjDD,8CAiDC;AAED;;GAEG;AACH,IAAY,cAoBX;AApBD,WAAY,cAAc;IACxB;;;;OAIG;IACH,uDAAqC,CAAA;IAErC;;;;;OAKG;IACH,qEAAmD,CAAA;IAEnD;;OAEG;IACH,iDAA+B,CAAA;AACjC,CAAC,EApBW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAoBzB;AAED;;GAEG;AACH,IAAY,qBAeX;AAfD,WAAY,qBAAqB;IAC/B;;OAEG;IACH,4CAAmB,CAAA;IAEnB;;OAEG;IACH,4CAAmB,CAAA;IAEnB;;OAEG;IACH,4CAAmB,CAAA;AACrB,CAAC,EAfW,qBAAqB,GAArB,6BAAqB,KAArB,6BAAqB,QAehC","sourcesContent":["import cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport cdk = require('@aws-cdk/cdk');\nimport { CfnScalingPolicy } from './applicationautoscaling.generated';\nimport { IScalableTarget } from './scalable-target';\n\n/**\n * Properties for a scaling policy\n */\nexport interface StepScalingActionProps {\n  /**\n   * The scalable target\n   */\n  readonly scalingTarget: IScalableTarget;\n\n  /**\n   * A name for the scaling policy\n   *\n   * @default Automatically generated name\n   */\n  readonly policyName?: string;\n\n  /**\n   * How the adjustment numbers are interpreted\n   *\n   * @default ChangeInCapacity\n   */\n  readonly adjustmentType?: AdjustmentType;\n\n  /**\n   * Grace period after scaling activity.\n   *\n   * For scale out policies, multiple scale outs during the cooldown period are\n   * squashed so that only the biggest scale out happens.\n   *\n   * For scale in policies, subsequent scale ins during the cooldown period are\n   * ignored.\n   *\n   * @see https://docs.aws.amazon.com/autoscaling/application/APIReference/API_StepScalingPolicyConfiguration.html\n   * @default No cooldown period\n   */\n  readonly cooldownSec?: number;\n\n  /**\n   * Minimum absolute number to adjust capacity with as result of percentage scaling.\n   *\n   * Only when using AdjustmentType = PercentChangeInCapacity, this number controls\n   * the minimum absolute effect size.\n   *\n   * @default No minimum scaling effect\n   */\n  readonly minAdjustmentMagnitude?: number;\n\n  /**\n   * The aggregation type for the CloudWatch metrics.\n   *\n   * @default Average\n   */\n  readonly metricAggregationType?: MetricAggregationType;\n}\n\n/**\n * Define a step scaling action\n *\n * This kind of scaling policy adjusts the target capacity in configurable\n * steps. The size of the step is configurable based on the metric's distance\n * to its alarm threshold.\n *\n * This Action must be used as the target of a CloudWatch alarm to take effect.\n */\nexport class StepScalingAction extends cdk.Construct implements cloudwatch.IAlarmAction {\n  /**\n   * ARN of the scaling policy\n   */\n  public readonly scalingPolicyArn: string;\n\n  /**\n   * ARN when this scaling policy is used as an Alarm action\n   */\n  public readonly alarmActionArn: string;\n\n  private readonly adjustments = new Array<CfnScalingPolicy.StepAdjustmentProperty>();\n\n  constructor(scope: cdk.Construct, id: string, props: StepScalingActionProps) {\n    super(scope, id);\n\n    // Cloudformation requires either the ResourceId, ScalableDimension, and ServiceNamespace\n    // properties, or the ScalingTargetId property, but not both.\n    // https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-applicationautoscaling-scalingpolicy.html\n    const resource = new CfnScalingPolicy(this, 'Resource', {\n      policyName: props.policyName || this.node.uniqueId,\n      policyType: 'StepScaling',\n      scalingTargetId: props.scalingTarget.scalableTargetId,\n      stepScalingPolicyConfiguration: {\n        adjustmentType: props.adjustmentType,\n        cooldown: props.cooldownSec,\n        minAdjustmentMagnitude: props.minAdjustmentMagnitude,\n        metricAggregationType: props.metricAggregationType,\n        stepAdjustments: new cdk.Token(() => this.adjustments),\n      } as CfnScalingPolicy.StepScalingPolicyConfigurationProperty\n    });\n\n    this.scalingPolicyArn = resource.scalingPolicyArn;\n    this.alarmActionArn = this.scalingPolicyArn;\n  }\n\n  /**\n   * Add an adjusment interval to the ScalingAction\n   */\n  public addAdjustment(adjustment: AdjustmentTier) {\n    if (adjustment.lowerBound === undefined && adjustment.upperBound === undefined) {\n      throw new Error('At least one of lowerBound or upperBound is required');\n    }\n    this.adjustments.push({\n      metricIntervalLowerBound: adjustment.lowerBound,\n      metricIntervalUpperBound: adjustment.upperBound,\n      scalingAdjustment: adjustment.adjustment,\n    });\n  }\n}\n\n/**\n * How adjustment numbers are interpreted\n */\nexport enum AdjustmentType {\n  /**\n   * Add the adjustment number to the current capacity.\n   *\n   * A positive number increases capacity, a negative number decreases capacity.\n   */\n  ChangeInCapacity = 'ChangeInCapacity',\n\n  /**\n   * Add this percentage of the current capacity to itself.\n   *\n   * The number must be between -100 and 100; a positive number increases\n   * capacity and a negative number decreases it.\n   */\n  PercentChangeInCapacity = 'PercentChangeInCapacity',\n\n  /**\n   * Make the capacity equal to the exact number given.\n   */\n  ExactCapacity = 'ExactCapacity',\n}\n\n/**\n * How the scaling metric is going to be aggregated\n */\nexport enum MetricAggregationType {\n  /**\n   * Average\n   */\n  Average = 'Average',\n\n  /**\n   * Minimum\n   */\n  Minimum = 'Minimum',\n\n  /**\n   * Maximum\n   */\n  Maximum = 'Maximum'\n}\n\n/**\n * An adjustment\n */\nexport interface AdjustmentTier {\n  /**\n   * What number to adjust the capacity with\n   *\n   * The number is interpeted as an added capacity, a new fixed capacity or an\n   * added percentage depending on the AdjustmentType value of the\n   * StepScalingPolicy.\n   *\n   * Can be positive or negative.\n   */\n  readonly adjustment: number;\n\n  /**\n   * Lower bound where this scaling tier applies.\n   *\n   * The scaling tier applies if the difference between the metric\n   * value and its alarm threshold is higher than this value.\n   *\n   * @default -Infinity if this is the first tier, otherwise the upperBound of the previous tier\n   */\n  readonly lowerBound?: number;\n\n  /**\n   * Upper bound where this scaling tier applies\n   *\n   * The scaling tier applies if the difference between the metric\n   * value and its alarm threshold is lower than this value.\n   *\n   * @default +Infinity\n   */\n  readonly upperBound?: number;\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step-scaling-action.js","sourceRoot":"","sources":["step-scaling-action.ts"],"names":[],"mappings":";;AAAA,oCAAqC;AACrC,yFAAsE;AA0DtE;;;;;;;;GAQG;AACH,MAAa,iBAAkB,SAAQ,GAAG,CAAC,SAAS;IAQlD,YAAY,KAAoB,EAAE,EAAU,EAAE,KAA6B;QACzE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAHF,gBAAW,GAAG,IAAI,KAAK,EAA2C,CAAC;QAKlF,yFAAyF;QACzF,6DAA6D;QAC7D,wHAAwH;QACxH,MAAM,QAAQ,GAAG,IAAI,mDAAgB,CAAC,IAAI,EAAE,UAAU,EAAE;YACtD,UAAU,EAAE,KAAK,CAAC,UAAU,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ;YAClD,UAAU,EAAE,aAAa;YACzB,eAAe,EAAE,KAAK,CAAC,aAAa,CAAC,gBAAgB;YACrD,8BAA8B,EAAE;gBAC9B,cAAc,EAAE,KAAK,CAAC,cAAc;gBACpC,QAAQ,EAAE,KAAK,CAAC,WAAW;gBAC3B,sBAAsB,EAAE,KAAK,CAAC,sBAAsB;gBACpD,qBAAqB,EAAE,KAAK,CAAC,qBAAqB;gBAClD,eAAe,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC;aACI;SAC7D,CAAC,CAAC;QAEH,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC,gBAAgB,CAAC;IACpD,CAAC;IAED;;OAEG;IACI,aAAa,CAAC,UAA0B;QAC7C,IAAI,UAAU,CAAC,UAAU,KAAK,SAAS,IAAI,UAAU,CAAC,UAAU,KAAK,SAAS,EAAE;YAC9E,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;SACzE;QACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YACpB,wBAAwB,EAAE,UAAU,CAAC,UAAU;YAC/C,wBAAwB,EAAE,UAAU,CAAC,UAAU;YAC/C,iBAAiB,EAAE,UAAU,CAAC,UAAU;SACzC,CAAC,CAAC;IACL,CAAC;CACF;AA3CD,8CA2CC;AAED;;GAEG;AACH,IAAY,cAoBX;AApBD,WAAY,cAAc;IACxB;;;;OAIG;IACH,uDAAqC,CAAA;IAErC;;;;;OAKG;IACH,qEAAmD,CAAA;IAEnD;;OAEG;IACH,iDAA+B,CAAA;AACjC,CAAC,EApBW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAoBzB;AAED;;GAEG;AACH,IAAY,qBAeX;AAfD,WAAY,qBAAqB;IAC/B;;OAEG;IACH,4CAAmB,CAAA;IAEnB;;OAEG;IACH,4CAAmB,CAAA;IAEnB;;OAEG;IACH,4CAAmB,CAAA;AACrB,CAAC,EAfW,qBAAqB,GAArB,6BAAqB,KAArB,6BAAqB,QAehC","sourcesContent":["import cdk = require('@aws-cdk/cdk');\nimport { CfnScalingPolicy } from './applicationautoscaling.generated';\nimport { IScalableTarget } from './scalable-target';\n\n/**\n * Properties for a scaling policy\n */\nexport interface StepScalingActionProps {\n  /**\n   * The scalable target\n   */\n  readonly scalingTarget: IScalableTarget;\n\n  /**\n   * A name for the scaling policy\n   *\n   * @default Automatically generated name\n   */\n  readonly policyName?: string;\n\n  /**\n   * How the adjustment numbers are interpreted\n   *\n   * @default ChangeInCapacity\n   */\n  readonly adjustmentType?: AdjustmentType;\n\n  /**\n   * Grace period after scaling activity.\n   *\n   * For scale out policies, multiple scale outs during the cooldown period are\n   * squashed so that only the biggest scale out happens.\n   *\n   * For scale in policies, subsequent scale ins during the cooldown period are\n   * ignored.\n   *\n   * @see https://docs.aws.amazon.com/autoscaling/application/APIReference/API_StepScalingPolicyConfiguration.html\n   * @default No cooldown period\n   */\n  readonly cooldownSec?: number;\n\n  /**\n   * Minimum absolute number to adjust capacity with as result of percentage scaling.\n   *\n   * Only when using AdjustmentType = PercentChangeInCapacity, this number controls\n   * the minimum absolute effect size.\n   *\n   * @default No minimum scaling effect\n   */\n  readonly minAdjustmentMagnitude?: number;\n\n  /**\n   * The aggregation type for the CloudWatch metrics.\n   *\n   * @default Average\n   */\n  readonly metricAggregationType?: MetricAggregationType;\n}\n\n/**\n * Define a step scaling action\n *\n * This kind of scaling policy adjusts the target capacity in configurable\n * steps. The size of the step is configurable based on the metric's distance\n * to its alarm threshold.\n *\n * This Action must be used as the target of a CloudWatch alarm to take effect.\n */\nexport class StepScalingAction extends cdk.Construct {\n  /**\n   * ARN of the scaling policy\n   */\n  public readonly scalingPolicyArn: string;\n\n  private readonly adjustments = new Array<CfnScalingPolicy.StepAdjustmentProperty>();\n\n  constructor(scope: cdk.Construct, id: string, props: StepScalingActionProps) {\n    super(scope, id);\n\n    // Cloudformation requires either the ResourceId, ScalableDimension, and ServiceNamespace\n    // properties, or the ScalingTargetId property, but not both.\n    // https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-applicationautoscaling-scalingpolicy.html\n    const resource = new CfnScalingPolicy(this, 'Resource', {\n      policyName: props.policyName || this.node.uniqueId,\n      policyType: 'StepScaling',\n      scalingTargetId: props.scalingTarget.scalableTargetId,\n      stepScalingPolicyConfiguration: {\n        adjustmentType: props.adjustmentType,\n        cooldown: props.cooldownSec,\n        minAdjustmentMagnitude: props.minAdjustmentMagnitude,\n        metricAggregationType: props.metricAggregationType,\n        stepAdjustments: new cdk.Token(() => this.adjustments),\n      } as CfnScalingPolicy.StepScalingPolicyConfigurationProperty\n    });\n\n    this.scalingPolicyArn = resource.scalingPolicyArn;\n  }\n\n  /**\n   * Add an adjusment interval to the ScalingAction\n   */\n  public addAdjustment(adjustment: AdjustmentTier) {\n    if (adjustment.lowerBound === undefined && adjustment.upperBound === undefined) {\n      throw new Error('At least one of lowerBound or upperBound is required');\n    }\n    this.adjustments.push({\n      metricIntervalLowerBound: adjustment.lowerBound,\n      metricIntervalUpperBound: adjustment.upperBound,\n      scalingAdjustment: adjustment.adjustment,\n    });\n  }\n}\n\n/**\n * How adjustment numbers are interpreted\n */\nexport enum AdjustmentType {\n  /**\n   * Add the adjustment number to the current capacity.\n   *\n   * A positive number increases capacity, a negative number decreases capacity.\n   */\n  ChangeInCapacity = 'ChangeInCapacity',\n\n  /**\n   * Add this percentage of the current capacity to itself.\n   *\n   * The number must be between -100 and 100; a positive number increases\n   * capacity and a negative number decreases it.\n   */\n  PercentChangeInCapacity = 'PercentChangeInCapacity',\n\n  /**\n   * Make the capacity equal to the exact number given.\n   */\n  ExactCapacity = 'ExactCapacity',\n}\n\n/**\n * How the scaling metric is going to be aggregated\n */\nexport enum MetricAggregationType {\n  /**\n   * Average\n   */\n  Average = 'Average',\n\n  /**\n   * Minimum\n   */\n  Minimum = 'Minimum',\n\n  /**\n   * Maximum\n   */\n  Maximum = 'Maximum'\n}\n\n/**\n * An adjustment\n */\nexport interface AdjustmentTier {\n  /**\n   * What number to adjust the capacity with\n   *\n   * The number is interpeted as an added capacity, a new fixed capacity or an\n   * added percentage depending on the AdjustmentType value of the\n   * StepScalingPolicy.\n   *\n   * Can be positive or negative.\n   */\n  readonly adjustment: number;\n\n  /**\n   * Lower bound where this scaling tier applies.\n   *\n   * The scaling tier applies if the difference between the metric\n   * value and its alarm threshold is higher than this value.\n   *\n   * @default -Infinity if this is the first tier, otherwise the upperBound of the previous tier\n   */\n  readonly lowerBound?: number;\n\n  /**\n   * Upper bound where this scaling tier applies\n   *\n   * The scaling tier applies if the difference between the metric\n   * value and its alarm threshold is lower than this value.\n   *\n   * @default +Infinity\n   */\n  readonly upperBound?: number;\n}"]}

@@ -48,3 +48,3 @@ "use strict";

});
this.lowerAlarm.addAlarmAction(this.lowerAction);
this.lowerAlarm.addAlarmAction(new StepScalingAlarmAction(this.lowerAction));
}

@@ -75,3 +75,3 @@ if (alarms.upperAlarmIntervalIndex !== undefined) {

});
this.upperAlarm.addAlarmAction(this.upperAction);
this.upperAlarm.addAlarmAction(new StepScalingAlarmAction(this.upperAction));
}

@@ -93,2 +93,19 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step-scaling-policy.js","sourceRoot":"","sources":["step-scaling-policy.ts"],"names":[],"mappings":";;AAAA,4EAA0F;AAC1F,sDAAuD;AACvD,oCAAqC;AAErC,+DAAiG;AAqDjG;;;;;;GAMG;AACH,MAAa,iBAAkB,SAAQ,GAAG,CAAC,SAAS;IAMlD,YAAY,KAAoB,EAAE,EAAU,EAAE,KAA6B;QACzE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,KAAK,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE;YACjC,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;SACzE;QAED,MAAM,cAAc,GAAG,KAAK,CAAC,cAAc,IAAI,oCAAc,CAAC,gBAAgB,CAAC;QAC/E,MAAM,kBAAkB,GAAG,cAAc,KAAK,oCAAc,CAAC,aAAa,CAAC;QAE3E,MAAM,SAAS,GAAG,2CAAkB,CAAC,KAAK,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;QAC7E,MAAM,MAAM,GAAG,4CAAmB,CAAC,SAAS,CAAC,CAAC;QAE9C,IAAI,MAAM,CAAC,uBAAuB,KAAK,SAAS,EAAE;YAChD,MAAM,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,uBAAuB,CAAC,CAAC,KAAK,CAAC;YAElE,IAAI,CAAC,WAAW,GAAG,IAAI,uCAAiB,CAAC,IAAI,EAAE,aAAa,EAAE;gBAC5D,cAAc;gBACd,WAAW,EAAE,KAAK,CAAC,WAAW;gBAC9B,qBAAqB,EAAE,yBAAyB,CAAC,KAAK,CAAC,MAAM,CAAC;gBAC9D,sBAAsB,EAAE,KAAK,CAAC,sBAAsB;gBACpD,aAAa,EAAE,KAAK,CAAC,aAAa;aACnC,CAAC,CAAC;YAEH,KAAK,IAAI,CAAC,GAAG,MAAM,CAAC,uBAAuB,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;gBACxD,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;oBAC7B,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,MAAO;oBAChC,UAAU,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,SAAS,CAAC,CAAC,CAAC,SAAS;oBAChE,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,SAAS;iBAC3C,CAAC,CAAC;aACJ;YAED,IAAI,CAAC,UAAU,GAAG,IAAI,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,YAAY,EAAE;gBACzD,6BAA6B;gBAC7B,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC;gBAC5C,gBAAgB,EAAE,+BAA+B;gBACjD,kBAAkB,EAAE,UAAU,CAAC,kBAAkB,CAAC,0BAA0B;gBAC5E,iBAAiB,EAAE,CAAC;gBACpB,SAAS;aACV,CAAC,CAAC;YACH,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SAClD;QAED,IAAI,MAAM,CAAC,uBAAuB,KAAK,SAAS,EAAE;YAChD,MAAM,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,uBAAuB,CAAC,CAAC,KAAK,CAAC;YAElE,IAAI,CAAC,WAAW,GAAG,IAAI,uCAAiB,CAAC,IAAI,EAAE,aAAa,EAAE;gBAC5D,cAAc;gBACd,WAAW,EAAE,KAAK,CAAC,WAAW;gBAC9B,qBAAqB,EAAE,yBAAyB,CAAC,KAAK,CAAC,MAAM,CAAC;gBAC9D,sBAAsB,EAAE,KAAK,CAAC,sBAAsB;gBACpD,aAAa,EAAE,KAAK,CAAC,aAAa;aACnC,CAAC,CAAC;YAEH,KAAK,IAAI,CAAC,GAAG,MAAM,CAAC,uBAAuB,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACtE,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;oBAC7B,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,MAAO;oBAChC,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,SAAS;oBAC1C,UAAU,EAAE,CAAC,KAAK,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,SAAS,CAAC,CAAC,CAAC,SAAS;iBACpF,CAAC,CAAC;aACJ;YAED,IAAI,CAAC,UAAU,GAAG,IAAI,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,YAAY,EAAE;gBACzD,6BAA6B;gBAC7B,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC;gBAC5C,gBAAgB,EAAE,+BAA+B;gBACjD,kBAAkB,EAAE,UAAU,CAAC,kBAAkB,CAAC,6BAA6B;gBAC/E,iBAAiB,EAAE,CAAC;gBACpB,SAAS;aACV,CAAC,CAAC;YACH,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SAClD;IACH,CAAC;CACF;AA/ED,8CA+EC;AAuCD,SAAS,yBAAyB,CAAC,MAAyB;IAC1D,QAAQ,MAAM,CAAC,SAAS,EAAE;QACxB,KAAK,SAAS;YACZ,OAAO,2CAAqB,CAAC,OAAO,CAAC;QACvC,KAAK,SAAS;YACZ,OAAO,2CAAqB,CAAC,OAAO,CAAC;QACvC,KAAK,SAAS;YACZ,OAAO,2CAAqB,CAAC,OAAO,CAAC;QACvC;YACE,MAAM,IAAI,KAAK,CAAC,qEAAqE,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC;KAC5G;AACH,CAAC","sourcesContent":["import { findAlarmThresholds, normalizeIntervals } from '@aws-cdk/aws-autoscaling-common';\nimport cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport cdk = require('@aws-cdk/cdk');\nimport { IScalableTarget } from './scalable-target';\nimport { AdjustmentType, MetricAggregationType, StepScalingAction } from './step-scaling-action';\n\nexport interface BasicStepScalingPolicyProps {\n  /**\n   * Metric to scale on.\n   */\n  readonly metric: cloudwatch.Metric;\n\n  /**\n   * The intervals for scaling.\n   *\n   * Maps a range of metric values to a particular scaling behavior.\n   */\n  readonly scalingSteps: ScalingInterval[];\n\n  /**\n   * How the adjustment numbers inside 'intervals' are interpreted.\n   *\n   * @default ChangeInCapacity\n   */\n  readonly adjustmentType?: AdjustmentType;\n\n  /**\n   * Grace period after scaling activity.\n   *\n   * Subsequent scale outs during the cooldown period are squashed so that only\n   * the biggest scale out happens.\n   *\n   * Subsequent scale ins during the cooldown period are ignored.\n   *\n   * @see https://docs.aws.amazon.com/autoscaling/application/APIReference/API_StepScalingPolicyConfiguration.html\n   * @default No cooldown period\n   */\n  readonly cooldownSec?: number;\n\n  /**\n   * Minimum absolute number to adjust capacity with as result of percentage scaling.\n   *\n   * Only when using AdjustmentType = PercentChangeInCapacity, this number controls\n   * the minimum absolute effect size.\n   *\n   * @default No minimum scaling effect\n   */\n  readonly minAdjustmentMagnitude?: number;\n}\n\nexport interface StepScalingPolicyProps extends BasicStepScalingPolicyProps {\n  /**\n   * The scaling target\n   */\n  readonly scalingTarget: IScalableTarget;\n}\n\n/**\n * Define a acaling strategy which scales depending on absolute values of some metric.\n *\n * You can specify the scaling behavior for various values of the metric.\n *\n * Implemented using one or more CloudWatch alarms and Step Scaling Policies.\n */\nexport class StepScalingPolicy extends cdk.Construct {\n  public readonly lowerAlarm?: cloudwatch.Alarm;\n  public readonly lowerAction?: StepScalingAction;\n  public readonly upperAlarm?: cloudwatch.Alarm;\n  public readonly upperAction?: StepScalingAction;\n\n  constructor(scope: cdk.Construct, id: string, props: StepScalingPolicyProps) {\n    super(scope, id);\n\n    if (props.scalingSteps.length < 2) {\n      throw new Error('You must supply at least 2 intervals for autoscaling');\n    }\n\n    const adjustmentType = props.adjustmentType || AdjustmentType.ChangeInCapacity;\n    const changesAreAbsolute = adjustmentType === AdjustmentType.ExactCapacity;\n\n    const intervals = normalizeIntervals(props.scalingSteps, changesAreAbsolute);\n    const alarms = findAlarmThresholds(intervals);\n\n    if (alarms.lowerAlarmIntervalIndex !== undefined) {\n      const threshold = intervals[alarms.lowerAlarmIntervalIndex].upper;\n\n      this.lowerAction = new StepScalingAction(this, 'LowerPolicy', {\n        adjustmentType,\n        cooldownSec: props.cooldownSec,\n        metricAggregationType: aggregationTypeFromMetric(props.metric),\n        minAdjustmentMagnitude: props.minAdjustmentMagnitude,\n        scalingTarget: props.scalingTarget,\n      });\n\n      for (let i = alarms.lowerAlarmIntervalIndex; i >= 0; i--) {\n        this.lowerAction.addAdjustment({\n          adjustment: intervals[i].change!,\n          lowerBound: i !== 0 ? intervals[i].lower - threshold : undefined, // Extend last interval to -infinity\n          upperBound: intervals[i].upper - threshold,\n        });\n      }\n\n      this.lowerAlarm = new cloudwatch.Alarm(this, 'LowerAlarm', {\n        // Recommended by AutoScaling\n        metric: props.metric.with({ periodSec: 60 }),\n        alarmDescription: 'Lower threshold scaling alarm',\n        comparisonOperator: cloudwatch.ComparisonOperator.LessThanOrEqualToThreshold,\n        evaluationPeriods: 1,\n        threshold,\n      });\n      this.lowerAlarm.addAlarmAction(this.lowerAction);\n    }\n\n    if (alarms.upperAlarmIntervalIndex !== undefined) {\n      const threshold = intervals[alarms.upperAlarmIntervalIndex].lower;\n\n      this.upperAction = new StepScalingAction(this, 'UpperPolicy', {\n        adjustmentType,\n        cooldownSec: props.cooldownSec,\n        metricAggregationType: aggregationTypeFromMetric(props.metric),\n        minAdjustmentMagnitude: props.minAdjustmentMagnitude,\n        scalingTarget: props.scalingTarget,\n      });\n\n      for (let i = alarms.upperAlarmIntervalIndex; i < intervals.length; i++) {\n        this.upperAction.addAdjustment({\n          adjustment: intervals[i].change!,\n          lowerBound: intervals[i].lower - threshold,\n          upperBound: i !== intervals.length - 1 ? intervals[i].upper - threshold : undefined, // Extend last interval to +infinity\n        });\n      }\n\n      this.upperAlarm = new cloudwatch.Alarm(this, 'UpperAlarm', {\n        // Recommended by AutoScaling\n        metric: props.metric.with({ periodSec: 60 }),\n        alarmDescription: 'Upper threshold scaling alarm',\n        comparisonOperator: cloudwatch.ComparisonOperator.GreaterThanOrEqualToThreshold,\n        evaluationPeriods: 1,\n        threshold,\n      });\n      this.upperAlarm.addAlarmAction(this.upperAction);\n    }\n  }\n}\n\n/**\n * A range of metric values in which to apply a certain scaling operation\n */\nexport interface ScalingInterval {\n  /**\n   * The lower bound of the interval.\n   *\n   * The scaling adjustment will be applied if the metric is higher than this value.\n   *\n   * @default Threshold automatically derived from neighbouring intervals\n   */\n  readonly lower?: number;\n\n  /**\n   * The upper bound of the interval.\n   *\n   * The scaling adjustment will be applied if the metric is lower than this value.\n   *\n   * @default Threshold automatically derived from neighbouring intervals\n   */\n  readonly upper?: number;\n\n  /**\n   * The capacity adjustment to apply in this interval\n   *\n   * The number is interpreted differently based on AdjustmentType:\n   *\n   * - ChangeInCapacity: add the adjustment to the current capacity.\n   *  The number can be positive or negative.\n   * - PercentChangeInCapacity: add or remove the given percentage of the current\n   *   capacity to itself. The number can be in the range [-100..100].\n   * - ExactCapacity: set the capacity to this number. The number must\n   *   be positive.\n   */\n  readonly change: number;\n}\n\nfunction aggregationTypeFromMetric(metric: cloudwatch.Metric): MetricAggregationType {\n  switch (metric.statistic) {\n    case 'Average':\n      return MetricAggregationType.Average;\n    case 'Minimum':\n      return MetricAggregationType.Minimum;\n    case 'Maximum':\n      return MetricAggregationType.Maximum;\n    default:\n      throw new Error(`Cannot only scale on 'Minimum', 'Maximum', 'Average' metrics, got ${metric.statistic}`);\n  }\n}"]}
/**
* Use a StepScalingAction as an Alarm Action
*
* This class is here and not in aws-cloudwatch-actions because this library
* needs to use the class, and otherwise we'd have a circular dependency:
*
* aws-autoscaling -> aws-cloudwatch-actions (for using the Action)
* aws-cloudwatch-actions -> aws-autoscaling (for the definition of IStepScalingAction)
*/
class StepScalingAlarmAction {
constructor(stepScalingAction) {
this.stepScalingAction = stepScalingAction;
}
bind(_scope, _alarm) {
return { alarmActionArn: this.stepScalingAction.scalingPolicyArn };
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step-scaling-policy.js","sourceRoot":"","sources":["step-scaling-policy.ts"],"names":[],"mappings":"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","sourcesContent":["import { findAlarmThresholds, normalizeIntervals } from '@aws-cdk/aws-autoscaling-common';\nimport cloudwatch = require('@aws-cdk/aws-cloudwatch');\nimport cdk = require('@aws-cdk/cdk');\nimport { IScalableTarget } from './scalable-target';\nimport { AdjustmentType, MetricAggregationType, StepScalingAction } from './step-scaling-action';\n\nexport interface BasicStepScalingPolicyProps {\n  /**\n   * Metric to scale on.\n   */\n  readonly metric: cloudwatch.Metric;\n\n  /**\n   * The intervals for scaling.\n   *\n   * Maps a range of metric values to a particular scaling behavior.\n   */\n  readonly scalingSteps: ScalingInterval[];\n\n  /**\n   * How the adjustment numbers inside 'intervals' are interpreted.\n   *\n   * @default ChangeInCapacity\n   */\n  readonly adjustmentType?: AdjustmentType;\n\n  /**\n   * Grace period after scaling activity.\n   *\n   * Subsequent scale outs during the cooldown period are squashed so that only\n   * the biggest scale out happens.\n   *\n   * Subsequent scale ins during the cooldown period are ignored.\n   *\n   * @see https://docs.aws.amazon.com/autoscaling/application/APIReference/API_StepScalingPolicyConfiguration.html\n   * @default No cooldown period\n   */\n  readonly cooldownSec?: number;\n\n  /**\n   * Minimum absolute number to adjust capacity with as result of percentage scaling.\n   *\n   * Only when using AdjustmentType = PercentChangeInCapacity, this number controls\n   * the minimum absolute effect size.\n   *\n   * @default No minimum scaling effect\n   */\n  readonly minAdjustmentMagnitude?: number;\n}\n\nexport interface StepScalingPolicyProps extends BasicStepScalingPolicyProps {\n  /**\n   * The scaling target\n   */\n  readonly scalingTarget: IScalableTarget;\n}\n\n/**\n * Define a acaling strategy which scales depending on absolute values of some metric.\n *\n * You can specify the scaling behavior for various values of the metric.\n *\n * Implemented using one or more CloudWatch alarms and Step Scaling Policies.\n */\nexport class StepScalingPolicy extends cdk.Construct {\n  public readonly lowerAlarm?: cloudwatch.Alarm;\n  public readonly lowerAction?: StepScalingAction;\n  public readonly upperAlarm?: cloudwatch.Alarm;\n  public readonly upperAction?: StepScalingAction;\n\n  constructor(scope: cdk.Construct, id: string, props: StepScalingPolicyProps) {\n    super(scope, id);\n\n    if (props.scalingSteps.length < 2) {\n      throw new Error('You must supply at least 2 intervals for autoscaling');\n    }\n\n    const adjustmentType = props.adjustmentType || AdjustmentType.ChangeInCapacity;\n    const changesAreAbsolute = adjustmentType === AdjustmentType.ExactCapacity;\n\n    const intervals = normalizeIntervals(props.scalingSteps, changesAreAbsolute);\n    const alarms = findAlarmThresholds(intervals);\n\n    if (alarms.lowerAlarmIntervalIndex !== undefined) {\n      const threshold = intervals[alarms.lowerAlarmIntervalIndex].upper;\n\n      this.lowerAction = new StepScalingAction(this, 'LowerPolicy', {\n        adjustmentType,\n        cooldownSec: props.cooldownSec,\n        metricAggregationType: aggregationTypeFromMetric(props.metric),\n        minAdjustmentMagnitude: props.minAdjustmentMagnitude,\n        scalingTarget: props.scalingTarget,\n      });\n\n      for (let i = alarms.lowerAlarmIntervalIndex; i >= 0; i--) {\n        this.lowerAction.addAdjustment({\n          adjustment: intervals[i].change!,\n          lowerBound: i !== 0 ? intervals[i].lower - threshold : undefined, // Extend last interval to -infinity\n          upperBound: intervals[i].upper - threshold,\n        });\n      }\n\n      this.lowerAlarm = new cloudwatch.Alarm(this, 'LowerAlarm', {\n        // Recommended by AutoScaling\n        metric: props.metric.with({ periodSec: 60 }),\n        alarmDescription: 'Lower threshold scaling alarm',\n        comparisonOperator: cloudwatch.ComparisonOperator.LessThanOrEqualToThreshold,\n        evaluationPeriods: 1,\n        threshold,\n      });\n      this.lowerAlarm.addAlarmAction(new StepScalingAlarmAction(this.lowerAction));\n    }\n\n    if (alarms.upperAlarmIntervalIndex !== undefined) {\n      const threshold = intervals[alarms.upperAlarmIntervalIndex].lower;\n\n      this.upperAction = new StepScalingAction(this, 'UpperPolicy', {\n        adjustmentType,\n        cooldownSec: props.cooldownSec,\n        metricAggregationType: aggregationTypeFromMetric(props.metric),\n        minAdjustmentMagnitude: props.minAdjustmentMagnitude,\n        scalingTarget: props.scalingTarget,\n      });\n\n      for (let i = alarms.upperAlarmIntervalIndex; i < intervals.length; i++) {\n        this.upperAction.addAdjustment({\n          adjustment: intervals[i].change!,\n          lowerBound: intervals[i].lower - threshold,\n          upperBound: i !== intervals.length - 1 ? intervals[i].upper - threshold : undefined, // Extend last interval to +infinity\n        });\n      }\n\n      this.upperAlarm = new cloudwatch.Alarm(this, 'UpperAlarm', {\n        // Recommended by AutoScaling\n        metric: props.metric.with({ periodSec: 60 }),\n        alarmDescription: 'Upper threshold scaling alarm',\n        comparisonOperator: cloudwatch.ComparisonOperator.GreaterThanOrEqualToThreshold,\n        evaluationPeriods: 1,\n        threshold,\n      });\n      this.upperAlarm.addAlarmAction(new StepScalingAlarmAction(this.upperAction));\n    }\n  }\n}\n\n/**\n * A range of metric values in which to apply a certain scaling operation\n */\nexport interface ScalingInterval {\n  /**\n   * The lower bound of the interval.\n   *\n   * The scaling adjustment will be applied if the metric is higher than this value.\n   *\n   * @default Threshold automatically derived from neighbouring intervals\n   */\n  readonly lower?: number;\n\n  /**\n   * The upper bound of the interval.\n   *\n   * The scaling adjustment will be applied if the metric is lower than this value.\n   *\n   * @default Threshold automatically derived from neighbouring intervals\n   */\n  readonly upper?: number;\n\n  /**\n   * The capacity adjustment to apply in this interval\n   *\n   * The number is interpreted differently based on AdjustmentType:\n   *\n   * - ChangeInCapacity: add the adjustment to the current capacity.\n   *  The number can be positive or negative.\n   * - PercentChangeInCapacity: add or remove the given percentage of the current\n   *   capacity to itself. The number can be in the range [-100..100].\n   * - ExactCapacity: set the capacity to this number. The number must\n   *   be positive.\n   */\n  readonly change: number;\n}\n\nfunction aggregationTypeFromMetric(metric: cloudwatch.Metric): MetricAggregationType {\n  switch (metric.statistic) {\n    case 'Average':\n      return MetricAggregationType.Average;\n    case 'Minimum':\n      return MetricAggregationType.Minimum;\n    case 'Maximum':\n      return MetricAggregationType.Maximum;\n    default:\n      throw new Error(`Cannot only scale on 'Minimum', 'Maximum', 'Average' metrics, got ${metric.statistic}`);\n  }\n}\n\n/**\n * Use a StepScalingAction as an Alarm Action\n *\n * This class is here and not in aws-cloudwatch-actions because this library\n * needs to use the class, and otherwise we'd have a circular dependency:\n *\n * aws-autoscaling -> aws-cloudwatch-actions (for using the Action)\n * aws-cloudwatch-actions -> aws-autoscaling (for the definition of IStepScalingAction)\n */\nclass StepScalingAlarmAction implements cloudwatch.IAlarmAction {\n  constructor(private readonly stepScalingAction: StepScalingAction) {\n  }\n\n  public bind(_scope: cdk.Construct, _alarm: cloudwatch.IAlarm): cloudwatch.AlarmActionConfig {\n    return { alarmActionArn: this.stepScalingAction.scalingPolicyArn };\n  }\n}\n"]}
{
"name": "@aws-cdk/aws-applicationautoscaling",
"version": "0.33.0",
"version": "0.34.0",
"description": "The CDK Construct Library for AWS::ApplicationAutoScaling",

@@ -27,2 +27,5 @@ "main": "lib/index.js",

}
},
"metadata": {
"awsdocs:title": "AWS Auto Scaling"
}

@@ -64,24 +67,25 @@ },

"devDependencies": {
"@aws-cdk/assert": "^0.33.0",
"cdk-build-tools": "^0.33.0",
"cfn2ts": "^0.33.0",
"fast-check": "^1.14.0",
"pkglint": "^0.33.0"
"@aws-cdk/assert": "^0.34.0",
"cdk-build-tools": "^0.34.0",
"cfn2ts": "^0.34.0",
"fast-check": "^1.15.1",
"pkglint": "^0.34.0"
},
"dependencies": {
"@aws-cdk/aws-autoscaling-common": "^0.33.0",
"@aws-cdk/aws-cloudwatch": "^0.33.0",
"@aws-cdk/aws-iam": "^0.33.0",
"@aws-cdk/cdk": "^0.33.0"
"@aws-cdk/aws-autoscaling-common": "^0.34.0",
"@aws-cdk/aws-cloudwatch": "^0.34.0",
"@aws-cdk/aws-iam": "^0.34.0",
"@aws-cdk/cdk": "^0.34.0"
},
"homepage": "https://github.com/awslabs/aws-cdk",
"peerDependencies": {
"@aws-cdk/aws-autoscaling-common": "^0.33.0",
"@aws-cdk/aws-cloudwatch": "^0.33.0",
"@aws-cdk/aws-iam": "^0.33.0",
"@aws-cdk/cdk": "^0.33.0"
"@aws-cdk/aws-autoscaling-common": "^0.34.0",
"@aws-cdk/aws-cloudwatch": "^0.34.0",
"@aws-cdk/aws-iam": "^0.34.0",
"@aws-cdk/cdk": "^0.34.0"
},
"engines": {
"node": ">= 8.10.0"
}
},
"stability": "experimental"
}

@@ -1,3 +0,15 @@

## AWS Application AutoScaling Construct Library
## AWS Auto Scaling Construct Library
<!--BEGIN STABILITY BANNER-->
---
![Stability: Experimental](https://img.shields.io/badge/stability-Experimental-important.svg?style=for-the-badge)
> This API is still under active development and subject to non-backward
> compatible changes or removal in any future version. Use of the API is not recommended in production
> environments. Experimental APIs are not subject to the Semantic Versioning model.
---
<!--END STABILITY BANNER-->
**Application AutoScaling** is used to configure autoscaling for all

@@ -4,0 +16,0 @@ services other than scaling EC2 instances. For example, you will use this to

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc