-
Notifications
You must be signed in to change notification settings - Fork 17
/
awsec2_CfnLaunchTemplate_EbsProperty.go
67 lines (64 loc) · 3.43 KB
/
awsec2_CfnLaunchTemplate_EbsProperty.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package awsec2
// Parameters for a block device for an EBS volume in an Amazon EC2 launch template.
//
// `Ebs` is a property of [AWS::EC2::LaunchTemplate BlockDeviceMapping](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ec2-launchtemplate-blockdevicemapping.html) .
//
// Example:
// // The code below shows an example of how to instantiate this type.
// // The values are placeholders you should change.
// import "github.com/aws/aws-cdk-go/awscdk"
//
// ebsProperty := &ebsProperty{
// deleteOnTermination: jsii.Boolean(false),
// encrypted: jsii.Boolean(false),
// iops: jsii.Number(123),
// kmsKeyId: jsii.String("kmsKeyId"),
// snapshotId: jsii.String("snapshotId"),
// throughput: jsii.Number(123),
// volumeSize: jsii.Number(123),
// volumeType: jsii.String("volumeType"),
// }
//
type CfnLaunchTemplate_EbsProperty struct {
// Indicates whether the EBS volume is deleted on instance termination.
DeleteOnTermination interface{} `field:"optional" json:"deleteOnTermination" yaml:"deleteOnTermination"`
// Indicates whether the EBS volume is encrypted.
//
// Encrypted volumes can only be attached to instances that support Amazon EBS encryption. If you are creating a volume from a snapshot, you can't specify an encryption value.
Encrypted interface{} `field:"optional" json:"encrypted" yaml:"encrypted"`
// The number of I/O operations per second (IOPS).
//
// For `gp3` , `io1` , and `io2` volumes, this represents the number of IOPS that are provisioned for the volume. For `gp2` volumes, this represents the baseline performance of the volume and the rate at which the volume accumulates I/O credits for bursting.
//
// The following are the supported values for each volume type:
//
// - `gp3` : 3,000-16,000 IOPS
// - `io1` : 100-64,000 IOPS
// - `io2` : 100-64,000 IOPS
//
// For `io1` and `io2` volumes, we guarantee 64,000 IOPS only for [Instances built on the Nitro System](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/instance-types.html#ec2-nitro-instances) . Other instance families guarantee performance up to 32,000 IOPS.
//
// This parameter is supported for `io1` , `io2` , and `gp3` volumes only. This parameter is not supported for `gp2` , `st1` , `sc1` , or `standard` volumes.
Iops *float64 `field:"optional" json:"iops" yaml:"iops"`
// The ARN of the symmetric AWS Key Management Service ( AWS KMS ) CMK used for encryption.
KmsKeyId *string `field:"optional" json:"kmsKeyId" yaml:"kmsKeyId"`
// The ID of the snapshot.
SnapshotId *string `field:"optional" json:"snapshotId" yaml:"snapshotId"`
// The throughput to provision for a `gp3` volume, with a maximum of 1,000 MiB/s.
//
// Valid Range: Minimum value of 125. Maximum value of 1000.
Throughput *float64 `field:"optional" json:"throughput" yaml:"throughput"`
// The size of the volume, in GiBs.
//
// You must specify either a snapshot ID or a volume size. The following are the supported volumes sizes for each volume type:
//
// - `gp2` and `gp3` : 1-16,384
// - `io1` and `io2` : 4-16,384
// - `st1` and `sc1` : 125-16,384
// - `standard` : 1-1,024.
VolumeSize *float64 `field:"optional" json:"volumeSize" yaml:"volumeSize"`
// The volume type.
//
// For more information, see [Amazon EBS volume types](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSVolumeTypes.html) in the *Amazon Elastic Compute Cloud User Guide* .
VolumeType *string `field:"optional" json:"volumeType" yaml:"volumeType"`
}