Interface VolumeProps

All Superinterfaces:
software.amazon.jsii.JsiiSerializable
All Known Implementing Classes:
VolumeProps.Jsii$Proxy

@Generated(value="jsii-pacmak/1.84.0 (build 5404dcf)", date="2023-06-19T16:30:39.551Z") @Stability(Stable) public interface VolumeProps extends software.amazon.jsii.JsiiSerializable
Properties of an EBS Volume.

Example:

 Instance instance;
 Role role;
 Volume volume = Volume.Builder.create(this, "Volume")
         .availabilityZone("us-west-2a")
         .size(Size.gibibytes(500))
         .encrypted(true)
         .build();
 volume.grantAttachVolume(role, List.of(instance));
 
  • Method Details

    • getAvailabilityZone

      @Stability(Stable) @NotNull String getAvailabilityZone()
      The Availability Zone in which to create the volume.
    • getAutoEnableIo

      @Stability(Stable) @Nullable default Boolean getAutoEnableIo()
      Indicates whether the volume is auto-enabled for I/O operations.

      By default, Amazon EBS disables I/O to the volume from attached EC2 instances when it determines that a volume's data is potentially inconsistent. If the consistency of the volume is not a concern, and you prefer that the volume be made available immediately if it's impaired, you can configure the volume to automatically enable I/O.

      Default: false

    • getEnableMultiAttach

      @Stability(Stable) @Nullable default Boolean getEnableMultiAttach()
      Indicates whether Amazon EBS Multi-Attach is enabled.

      See

      invalid @link
      {@link https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ebs-volumes-multi.html#considerations|Considerations
      and limitations} for the constraints of multi-attach.

      Default: false

    • getEncrypted

      @Stability(Stable) @Nullable default Boolean getEncrypted()
      Specifies whether the volume should be encrypted.

      The effect of setting the encryption state to true depends on the volume origin (new or from a snapshot), starting encryption state, ownership, and whether encryption by default is enabled. For more information, see

      invalid @link
      {@link https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSEncryption.html#encryption-by-default|Encryption
      by Default} in the Amazon Elastic Compute Cloud User Guide. Encrypted Amazon EBS volumes must be attached to instances that support Amazon EBS encryption. For more information, see
      invalid @link
      {@link https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSEncryption.html#EBSEncryption_supported_instances|Supported
      Instance Types.}

      Default: false

    • getEncryptionKey

      @Stability(Stable) @Nullable default IKey getEncryptionKey()
      The customer-managed encryption key that is used to encrypt the Volume.

      The encrypted property must be true if this is provided. Note: If using an

      invalid @link
      {@link aws-kms.IKey
      } created from a
      invalid @link
      {@link aws-kms.Key.fromKeyArn()
      } here, then the KMS key **must** have the following in its Key policy; otherwise, the Volume will fail to create. ``` { "Effect": "Allow", "Principal": { "AWS": " ex: arn:aws:iam::00000000000:root" }, "Resource": "*", "Action": [ "kms:DescribeKey", "kms:GenerateDataKeyWithoutPlainText", ], "Condition": { "StringEquals": { "kms:ViaService": "ec2..amazonaws.com", (eg: ec2.us-east-1.amazonaws.com) "kms:CallerAccount": "0000000000" (your account ID) } } } ```

      Default: The default KMS key for the account, region, and EC2 service is used.

    • getIops

      @Stability(Stable) @Nullable default Number getIops()
      The number of I/O operations per second (IOPS) to provision for the volume.

      The maximum ratio is 50 IOPS/GiB for PROVISIONED_IOPS_SSD, and 500 IOPS/GiB for both PROVISIONED_IOPS_SSD_IO2 and GENERAL_PURPOSE_SSD_GP3. See

      invalid @link
      {@link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-ebs-volume.html
      } for more information. This parameter is valid only for PROVISIONED_IOPS_SSD, PROVISIONED_IOPS_SSD_IO2 and GENERAL_PURPOSE_SSD_GP3 volumes.

      Default: None -- Required for io1 and io2 volumes. The default for gp3 volumes is 3,000 IOPS if omitted.

    • getRemovalPolicy

      @Stability(Stable) @Nullable default RemovalPolicy getRemovalPolicy()
      Policy to apply when the volume is removed from the stack.

      Default: RemovalPolicy.RETAIN

    • getSize

      @Stability(Stable) @Nullable default Size getSize()
      The size of the volume, in GiBs.

      You must specify either a snapshot ID or a volume size. See

      invalid @link
      {@link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-ebs-volume.html
      } for details on the allowable size for each type of volume.

      Default: If you're creating the volume from a snapshot and don't specify a volume size, the default is the snapshot size.

    • getSnapshotId

      @Stability(Stable) @Nullable default String getSnapshotId()
      The snapshot from which to create the volume.

      You must specify either a snapshot ID or a volume size.

      Default: The EBS volume is not created from a snapshot.

    • getVolumeName

      @Stability(Stable) @Nullable default String getVolumeName()
      The value of the physicalName property of this resource.

      Default: The physical name will be allocated by CloudFormation at deployment time

    • getVolumeType

      @Stability(Stable) @Nullable default EbsDeviceVolumeType getVolumeType()
      The type of the volume;

      what type of storage to use to form the EBS Volume.

      Default:

      invalid @link
      EbsDeviceVolumeType.GENERAL_PURPOSE_SSD
    • builder

      @Stability(Stable) static VolumeProps.Builder builder()
      Returns:
      a VolumeProps.Builder of VolumeProps