alicloud_ecs_disk
Provides an ECS Disk resource.
For information about ECS Disk and how to use it, see What is Disk.
-> NOTE: Available since v1.122.0.
Example Usage
Basic Usage
data "alicloud_zones" "example" {
available_resource_creation = "VSwitch"
}
resource "alicloud_kms_key" "example" {
description = "terraform-example"
pending_window_in_days = "7"
status = "Enabled"
}
resource "alicloud_ecs_disk" "example" {
zone_id = data.alicloud_zones.example.zones.0.id
disk_name = "terraform-example"
description = "terraform-example"
category = "cloud_efficiency"
size = "30"
encrypted = true
kms_key_id = alicloud_kms_key.example.id
tags = {
Name = "terraform-example"
}
}
Deleting alicloud_ecs_disk
or removing it from your configuration
The alicloud_ecs_disk
resource allows you to manage payment_type = "Subscription"
and delete_with_instance = true
disk,
but Terraform cannot destroy it. Deleting the subscription resource or removing it from your configuration will
remove it from your state file and management, but will not destroy it.
If you want to delete it, you can change it to PayAsYouGo
and setting delete_with_instance = true
and detach it from instance.
Argument Reference
The following arguments are supported:
bursting_enabled
- (Optional, Bool, Available since v1.237.0) Specifies whether to enable the performance burst feature. Valid values:true
,false
. NOTE:bursting_enabled
is only valid whencategory
iscloud_auto
.category
- (Optional) The category of the data disk. Default value:cloud_efficiency
. Valid Values:cloud
,cloud_efficiency
,cloud_ssd
,cloud_essd
,cloud_auto
,cloud_essd_entry
,elastic_ephemeral_disk_standard
,elastic_ephemeral_disk_premium
.delete_auto_snapshot
- (Optional, Bool) Specifies whether to delete the automatic snapshots of the disk when the disk is released. Default value:false
.delete_with_instance
- (Optional, Bool) Specifies whether to release the disk along with its associated instance. Default value:false
.description
- (Optional) The description of the disk. The description must be 2 to 256 characters in length and cannot start with http:// or https://.disk_name
- (Optional) The name of the data disk. The name must be 2 to 128 characters in length and can contain letters, digits, colons (:), underscores (_), periods (.), and hyphens (-). The name must start with a letter.dry_run
- (Optional, Bool) Specifies whether to check the validity of the request without actually making the request.request Default value:false
. Valid values:true
: The validity of the request is checked, but the request is not made. Check items include the required parameters, request format, service limits, and available ECS resources. If the check fails, the corresponding error message is returned. If the check succeeds, the DryRunOperation error code is returned.false
: The validity of the request is checked. If the check succeeds, a 2xx HTTP status code is returned and the request is made.
enable_auto_snapshot
- (Optional, Bool) Specifies whether to enable the automatic snapshot policy feature for the cloud disk. Valid values:true
,false
.encrypted
- (Optional, ForceNew, Bool) Specifies whether to encrypt the disk. Default value:false
. Valid values:true
: Enable.false
: Disable.
instance_id
- (Optional, ForceNew) The ID of the instance to which the created subscription disk is automatically attached.- After you specify the instance ID, the specified
resource_group_id
,tags
, andkms_key_id
parameters are ignored. - One of the
zone_id
andinstance_id
must be set but can not be set at the same time.
- After you specify the instance ID, the specified
kms_key_id
- (Optional, ForceNew) The ID of the Key Management Service (KMS) key that is used for the disk. NOTE:kms_key_id
is only valid whenencrypted
istrue
.multi_attach
- (Optional, ForceNew, Available since v1.237.0) Specifies whether to enable the multi-attach feature for the disk. Default value:Disabled
. Valid values:Enabled
,Disabled
. NOTE: Currently,multi_attach
can only be set toEnabled
whencategory
is set tocloud_essd
.payment_type
- (Optional) The payment type of the disk. Default toPayAsYouGo
. Valid values:PayAsYouGo
,Subscription
. If you want to change the disk payment type, theinstance_id
is required.performance_level
- (Optional) Specifies the performance level of an ESSD when you create the ESSD. Valid values:PL0
: A single ESSD delivers up to 10,000 random read/write IOPS.PL1
: A single ESSD delivers up to 50,000 random read/write IOPS.PL2
: A single ESSD delivers up to 100,000 random read/write IOPS.PL3
: A single ESSD delivers up to 1,000,000 random read/write IOPS.
provisioned_iops
- (Optional, Int, Available since v1.237.0) The provisioned read/write IOPS of the ESSD AutoPL disk. Valid values: 0 to min{50,000, 1,000 × Capacity - Baseline IOPS}. NOTE:provisioned_iops
is only valid whencategory
iscloud_auto
.resource_group_id
- (Optional) The ID of the resource group to which to add the disk.size
- (Optional, Int) The size of the disk. Unit: GiB. This parameter is required. Valid values:- If
category
is set tocloud
. Valid values:5
to2000
. - If
category
is set tocloud_efficiency
. Valid values:20
to32768
. - If
category
is set tocloud_ssd
. Valid values:20
to32768
. - If
category
is set tocloud_auto
. Valid values:1
to65536
. - If
category
is set tocloud_essd_entry
. Valid values:10
to32768
. - If
category
is set toelastic_ephemeral_disk_standard
. Valid values:64
to8192
. - If
category
is set toelastic_ephemeral_disk_premium
. Valid values:64
to8192
. - If
category
is set tocloud_essd
, the valid values are related toperformance_level
. Valid values:- If
performance_level
is set toPL0
. Valid values:1
to65536
. - If
performance_level
is set toPL1
. Valid values:20
to65536
. - If
performance_level
is set toPL2
. Valid values:461
to65536
. - If
performance_level
is set toPL3
. Valid values:1261
to65536
.
- If
- If
snapshot_id
- (Optional, ForceNew) The ID of the snapshot to use to create the disk. NOTE: If the size of the snapshot specified bysnapshot_id
is larger than the value ofsize
, the size of the created disk is equal to the specified snapshot size. If the size of the snapshot specified bysnapshot_id
is smaller than the value ofsize
, the size of the created disk is equal to the value ofsize
.storage_set_id
- (Optional, ForceNew) The ID of the storage set.storage_set_partition_number
- (Optional, ForceNew) The number of partitions in the storage set.tags
- (Optional) A mapping of tags to assign to the resource.type
- (Optional, Available since v1.122.0) The type to expand cloud disks. Valid Values:online
,offline
. Default tooffline
.offline
: After you resize a disk offline, you must restart the instance by using the console or by calling the RebootInstance operation for the resizing operation to take effect. For more information, see Restart the instance and RebootInstance.online
: After you resize a disk online, the resizing operation takes effect immediately and you do not need to restart the instance. You can resize ultra disks, standard SSDs, and ESSDs online.
zone_id
- (Optional, ForceNew) ID of the free zone to which the disk belongs. One of thezone_id
andinstance_id
must be set but can not be set at the same time.availability_zone
- (Deprecated since v1.122.0) Fieldavailability_zone
has been deprecated from provider version 1.122.0. New fieldzone_id
instead.name
- (Optional, Deprecated since v1.122.0) Fieldname
has been deprecated from provider version 1.122.0. New fielddisk_name
instead.
-> NOTE: Disk category cloud
has been outdated, and it only can be used none I/O Optimized ECS instances. Recommend cloud_efficiency
and cloud_ssd
disk.
Attributes Reference
The following attributes are exported:
id
- The resource ID in terraform of Disk.create_time
- (Available since v1.237.0) The time when the disk was created.region_id
- (Available since v1.237.0) The ID of the region to which the disk belongs.status
- The status of the disk.
Timeouts
The timeouts
block allows you to specify timeouts for certain actions:
create
- (Defaults to 5 mins) Used when create the Disk.delete
- (Defaults to 5 mins) Used when delete the Disk.update
- (Defaults to 15 mins) Used when update the Disk.
Import
ECS Disk can be imported using the id, e.g.
$ terraform import alicloud_ecs_disk.example <id>