Class AsgCapacityProvider

java.lang.Object
software.amazon.jsii.JsiiObject
software.constructs.Construct
software.amazon.awscdk.core.Construct
software.amazon.awscdk.services.ecs.AsgCapacityProvider
All Implemented Interfaces:
IConstruct, IDependable, software.amazon.jsii.JsiiSerializable, software.constructs.IConstruct

@Generated(value="jsii-pacmak/1.84.0 (build 5404dcf)", date="2023-06-19T16:30:46.978Z") @Stability(Stable) public class AsgCapacityProvider extends Construct
An Auto Scaling Group Capacity Provider.

This allows an ECS cluster to target a specific EC2 Auto Scaling Group for the placement of tasks. Optionally (and recommended), ECS can manage the number of instances in the ASG to fit the tasks, and can ensure that instances are not prematurely terminated while there are still tasks running on them.

Example:

 Vpc vpc;
 Cluster cluster = Cluster.Builder.create(this, "Cluster")
         .vpc(vpc)
         .build();
 AutoScalingGroup autoScalingGroup = AutoScalingGroup.Builder.create(this, "ASG")
         .vpc(vpc)
         .instanceType(new InstanceType("t2.micro"))
         .machineImage(EcsOptimizedImage.amazonLinux2())
         .minCapacity(0)
         .maxCapacity(100)
         .build();
 AsgCapacityProvider capacityProvider = AsgCapacityProvider.Builder.create(this, "AsgCapacityProvider")
         .autoScalingGroup(autoScalingGroup)
         .build();
 cluster.addAsgCapacityProvider(capacityProvider);
 Ec2TaskDefinition taskDefinition = new Ec2TaskDefinition(this, "TaskDef");
 taskDefinition.addContainer("web", ContainerDefinitionOptions.builder()
         .image(ContainerImage.fromRegistry("amazon/amazon-ecs-sample"))
         .memoryReservationMiB(256)
         .build());
 Ec2Service.Builder.create(this, "EC2Service")
         .cluster(cluster)
         .taskDefinition(taskDefinition)
         .capacityProviderStrategies(List.of(CapacityProviderStrategy.builder()
                 .capacityProvider(capacityProvider.getCapacityProviderName())
                 .weight(1)
                 .build()))
         .build();
 
  • Constructor Details

    • AsgCapacityProvider

      protected AsgCapacityProvider(software.amazon.jsii.JsiiObjectRef objRef)
    • AsgCapacityProvider

      protected AsgCapacityProvider(software.amazon.jsii.JsiiObject.InitializationMode initializationMode)
    • AsgCapacityProvider

      @Stability(Stable) public AsgCapacityProvider(@NotNull software.constructs.Construct scope, @NotNull String id, @NotNull AsgCapacityProviderProps props)
      Parameters:
      scope - This parameter is required.
      id - This parameter is required.
      props - This parameter is required.
  • Method Details

    • getAutoScalingGroup

      @Stability(Stable) @NotNull public AutoScalingGroup getAutoScalingGroup()
      Auto Scaling Group.
    • getCapacityProviderName

      @Stability(Stable) @NotNull public String getCapacityProviderName()
      Capacity provider name.

      Default: Chosen by CloudFormation

    • getMachineImageType

      @Stability(Stable) @NotNull public MachineImageType getMachineImageType()
      Auto Scaling Group machineImageType.
    • getCanContainersAccessInstanceRole

      @Stability(Stable) @Nullable public Boolean getCanContainersAccessInstanceRole()
      Specifies whether the containers can access the container instance role.

      Default: false

    • getEnableManagedTerminationProtection

      @Stability(Stable) @Nullable public Boolean getEnableManagedTerminationProtection()
      Whether managed termination protection is enabled.