NAME

Paws::EC2::CreateFleet - Arguments for method CreateFleet on Paws::EC2

DESCRIPTION

This class represents the parameters used for calling the method CreateFleet on the Amazon Elastic Compute Cloud service. Use the attributes of this class as arguments to method CreateFleet.

You shouldn't make instances of this class. Each attribute should be used as a named argument in the call to CreateFleet.

SYNOPSIS

my $ec2 = Paws->service('EC2');
my $CreateFleetResult = $ec2->CreateFleet(
  LaunchTemplateConfigs => [
    {
      LaunchTemplateSpecification => {
        LaunchTemplateId   => 'MyLaunchTemplateId',    # OPTIONAL
        LaunchTemplateName =>
          'MyLaunchTemplateName',    # min: 3, max: 128; OPTIONAL
        Version => 'MyString',       # OPTIONAL
      },    # OPTIONAL
      Overrides => [
        {
          AvailabilityZone => 'MyString',    # OPTIONAL
          InstanceType     => 't1.micro'
          , # values: t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, t2.xlarge, t2.2xlarge, t3.nano, t3.micro, t3.small, t3.medium, t3.large, t3.xlarge, t3.2xlarge, t3a.nano, t3a.micro, t3a.small, t3a.medium, t3a.large, t3a.xlarge, t3a.2xlarge, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, r4.large, r4.xlarge, r4.2xlarge, r4.4xlarge, r4.8xlarge, r4.16xlarge, r5.large, r5.xlarge, r5.2xlarge, r5.4xlarge, r5.8xlarge, r5.12xlarge, r5.16xlarge, r5.24xlarge, r5.metal, r5a.large, r5a.xlarge, r5a.2xlarge, r5a.4xlarge, r5a.8xlarge, r5a.12xlarge, r5a.16xlarge, r5a.24xlarge, r5d.large, r5d.xlarge, r5d.2xlarge, r5d.4xlarge, r5d.8xlarge, r5d.12xlarge, r5d.16xlarge, r5d.24xlarge, r5d.metal, r5ad.large, r5ad.xlarge, r5ad.2xlarge, r5ad.4xlarge, r5ad.8xlarge, r5ad.12xlarge, r5ad.16xlarge, r5ad.24xlarge, x1.16xlarge, x1.32xlarge, x1e.xlarge, x1e.2xlarge, x1e.4xlarge, x1e.8xlarge, x1e.16xlarge, x1e.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, i3.large, i3.xlarge, i3.2xlarge, i3.4xlarge, i3.8xlarge, i3.16xlarge, i3.metal, i3en.large, i3en.xlarge, i3en.2xlarge, i3en.3xlarge, i3en.6xlarge, i3en.12xlarge, i3en.24xlarge, i3en.metal, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, c5.large, c5.xlarge, c5.2xlarge, c5.4xlarge, c5.9xlarge, c5.12xlarge, c5.18xlarge, c5.24xlarge, c5.metal, c5d.large, c5d.xlarge, c5d.2xlarge, c5d.4xlarge, c5d.9xlarge, c5d.12xlarge, c5d.18xlarge, c5d.24xlarge, c5d.metal, c5n.large, c5n.xlarge, c5n.2xlarge, c5n.4xlarge, c5n.9xlarge, c5n.18xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, g3.4xlarge, g3.8xlarge, g3.16xlarge, g3s.xlarge, g4dn.xlarge, g4dn.2xlarge, g4dn.4xlarge, g4dn.8xlarge, g4dn.12xlarge, g4dn.16xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, p3.2xlarge, p3.8xlarge, p3.16xlarge, p3dn.24xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge, f1.2xlarge, f1.4xlarge, f1.16xlarge, m5.large, m5.xlarge, m5.2xlarge, m5.4xlarge, m5.8xlarge, m5.12xlarge, m5.16xlarge, m5.24xlarge, m5.metal, m5a.large, m5a.xlarge, m5a.2xlarge, m5a.4xlarge, m5a.8xlarge, m5a.12xlarge, m5a.16xlarge, m5a.24xlarge, m5d.large, m5d.xlarge, m5d.2xlarge, m5d.4xlarge, m5d.8xlarge, m5d.12xlarge, m5d.16xlarge, m5d.24xlarge, m5d.metal, m5ad.large, m5ad.xlarge, m5ad.2xlarge, m5ad.4xlarge, m5ad.8xlarge, m5ad.12xlarge, m5ad.16xlarge, m5ad.24xlarge, h1.2xlarge, h1.4xlarge, h1.8xlarge, h1.16xlarge, z1d.large, z1d.xlarge, z1d.2xlarge, z1d.3xlarge, z1d.6xlarge, z1d.12xlarge, z1d.metal, u-6tb1.metal, u-9tb1.metal, u-12tb1.metal, u-18tb1.metal, u-24tb1.metal, a1.medium, a1.large, a1.xlarge, a1.2xlarge, a1.4xlarge, a1.metal, m5dn.large, m5dn.xlarge, m5dn.2xlarge, m5dn.4xlarge, m5dn.8xlarge, m5dn.12xlarge, m5dn.16xlarge, m5dn.24xlarge, m5n.large, m5n.xlarge, m5n.2xlarge, m5n.4xlarge, m5n.8xlarge, m5n.12xlarge, m5n.16xlarge, m5n.24xlarge, r5dn.large, r5dn.xlarge, r5dn.2xlarge, r5dn.4xlarge, r5dn.8xlarge, r5dn.12xlarge, r5dn.16xlarge, r5dn.24xlarge, r5n.large, r5n.xlarge, r5n.2xlarge, r5n.4xlarge, r5n.8xlarge, r5n.12xlarge, r5n.16xlarge, r5n.24xlarge, inf1.xlarge, inf1.2xlarge, inf1.6xlarge, inf1.24xlarge; OPTIONAL
          MaxPrice  => 'MyString',    # OPTIONAL
          Placement => {
            Affinity             => 'MyString',    # OPTIONAL
            AvailabilityZone     => 'MyString',    # OPTIONAL
            GroupName            => 'MyString',    # OPTIONAL
            HostId               => 'MyString',    # OPTIONAL
            HostResourceGroupArn => 'MyString',    # OPTIONAL
            PartitionNumber      => 1,             # OPTIONAL
            SpreadDomain         => 'MyString',    # OPTIONAL
            Tenancy              =>
              'default',    # values: default, dedicated, host; OPTIONAL
          },    # OPTIONAL
          Priority         => 1,               # OPTIONAL
          SubnetId         => 'MySubnetId',    # OPTIONAL
          WeightedCapacity => 1,               # OPTIONAL
        },
        ...
      ],    # max: 50; OPTIONAL
    },
    ...
  ],
  TargetCapacitySpecification => {
    TotalTargetCapacity       => 1,      # OPTIONAL
    DefaultTargetCapacityType => 'spot', # values: spot, on-demand; OPTIONAL
    OnDemandTargetCapacity    => 1,      # OPTIONAL
    SpotTargetCapacity        => 1,      # OPTIONAL
  },
  ClientToken                     => 'MyString',          # OPTIONAL
  DryRun                          => 1,                   # OPTIONAL
  ExcessCapacityTerminationPolicy => 'no-termination',    # OPTIONAL
  OnDemandOptions                 => {
    AllocationStrategy =>
      'lowest-price',    # values: lowest-price, prioritized; OPTIONAL
    CapacityReservationOptions => {
      UsageStrategy => 'use-capacity-reservations-first'
      ,                  # values: use-capacity-reservations-first; OPTIONAL
    },    # OPTIONAL
    MaxTotalPrice          => 'MyString',    # OPTIONAL
    MinTargetCapacity      => 1,             # OPTIONAL
    SingleAvailabilityZone => 1,
    SingleInstanceType     => 1,
  },    # OPTIONAL
  ReplaceUnhealthyInstances => 1,    # OPTIONAL
  SpotOptions               => {
    AllocationStrategy => 'lowest-price'
    ,    # values: lowest-price, diversified, capacity-optimized; OPTIONAL
    InstanceInterruptionBehavior =>
      'hibernate',    # values: hibernate, stop, terminate; OPTIONAL
    InstancePoolsToUseCount => 1,             # OPTIONAL
    MaxTotalPrice           => 'MyString',    # OPTIONAL
    MinTargetCapacity       => 1,             # OPTIONAL
    SingleAvailabilityZone  => 1,
    SingleInstanceType      => 1,
  },    # OPTIONAL
  TagSpecifications => [
    {
      ResourceType => 'client-vpn-endpoint'
      , # values: client-vpn-endpoint, customer-gateway, dedicated-host, dhcp-options, elastic-ip, fleet, fpga-image, host-reservation, image, instance, internet-gateway, key-pair, launch-template, natgateway, network-acl, network-interface, placement-group, reserved-instances, route-table, security-group, snapshot, spot-fleet-request, spot-instances-request, subnet, traffic-mirror-filter, traffic-mirror-session, traffic-mirror-target, transit-gateway, transit-gateway-attachment, transit-gateway-multicast-domain, transit-gateway-route-table, volume, vpc, vpc-peering-connection, vpn-connection, vpn-gateway; OPTIONAL
      Tags => [
        {
          Key   => 'MyString',    # OPTIONAL
          Value => 'MyString',    # OPTIONAL
        },
        ...
      ],    # OPTIONAL
    },
    ...
  ],    # OPTIONAL
  TerminateInstancesWithExpiration => 1,                        # OPTIONAL
  Type                             => 'request',                # OPTIONAL
  ValidFrom                        => '1970-01-01T01:00:00',    # OPTIONAL
  ValidUntil                       => '1970-01-01T01:00:00',    # OPTIONAL
);

# Results:
my $Errors    = $CreateFleetResult->Errors;
my $FleetId   = $CreateFleetResult->FleetId;
my $Instances = $CreateFleetResult->Instances;

# Returns a L<Paws::EC2::CreateFleetResult> object.

Values for attributes that are native types (Int, String, Float, etc) can passed as-is (scalar values). Values for complex Types (objects) can be passed as a HashRef. The keys and values of the hashref will be used to instance the underlying object. For the AWS API documentation, see https://docs.aws.amazon.com/goto/WebAPI/ec2/CreateFleet

ATTRIBUTES

ClientToken => Str

Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. For more information, see Ensuring Idempotency (https://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html).

DryRun => Bool

Checks whether you have the required permissions for the action, without actually making the request, and provides an error response. If you have the required permissions, the error response is DryRunOperation. Otherwise, it is UnauthorizedOperation.

ExcessCapacityTerminationPolicy => Str

Indicates whether running instances should be terminated if the total target capacity of the EC2 Fleet is decreased below the current size of the EC2 Fleet.

Valid values are: "no-termination", "termination"

REQUIRED LaunchTemplateConfigs => ArrayRef[Paws::EC2::FleetLaunchTemplateConfigRequest]

The configuration for the EC2 Fleet.

OnDemandOptions => Paws::EC2::OnDemandOptionsRequest

Describes the configuration of On-Demand Instances in an EC2 Fleet.

ReplaceUnhealthyInstances => Bool

Indicates whether EC2 Fleet should replace unhealthy instances.

SpotOptions => Paws::EC2::SpotOptionsRequest

Describes the configuration of Spot Instances in an EC2 Fleet.

TagSpecifications => ArrayRef[Paws::EC2::TagSpecification]

The key-value pair for tagging the EC2 Fleet request on creation. The value for ResourceType must be fleet, otherwise the fleet request fails. To tag instances at launch, specify the tags in the launch template (https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-launch-templates.html#create-launch-template). For information about tagging after launch, see Tagging Your Resources (https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Using_Tags.html#tag-resources).

REQUIRED TargetCapacitySpecification => Paws::EC2::TargetCapacitySpecificationRequest

The number of units to request.

TerminateInstancesWithExpiration => Bool

Indicates whether running instances should be terminated when the EC2 Fleet expires.

Type => Str

The type of the request. By default, the EC2 Fleet places an asynchronous request for your desired capacity, and maintains it by replenishing interrupted Spot Instances (maintain). A value of instant places a synchronous one-time request, and returns errors for any instances that could not be launched. A value of request places an asynchronous one-time request without maintaining capacity or submitting requests in alternative capacity pools if capacity is unavailable. For more information, see EC2 Fleet Request Types (https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-fleet-configuration-strategies.html#ec2-fleet-request-type) in the Amazon Elastic Compute Cloud User Guide.

Valid values are: "request", "maintain", "instant"

ValidFrom => Str

The start date and time of the request, in UTC format (for example, YYYY-MM-DDTHH:MM:SSZ). The default is to start fulfilling the request immediately.

ValidUntil => Str

The end date and time of the request, in UTC format (for example, YYYY-MM-DDTHH:MM:SSZ). At this point, no new EC2 Fleet requests are placed or able to fulfill the request. If no value is specified, the request remains until you cancel it.

SEE ALSO

This class forms part of Paws, documenting arguments for method CreateFleet in Paws::EC2

BUGS and CONTRIBUTIONS

The source code is located here: https://github.com/pplu/aws-sdk-perl

Please report bugs to: https://github.com/pplu/aws-sdk-perl/issues