EcsSnapshotGroup

class EcsSnapshotGroup : KotlinCustomResource

Provides a ECS Snapshot Group resource. For information about ECS Snapshot Group and how to use it, see What is Snapshot Group.

NOTE: Available in v1.160.0+.

Example Usage

Basic Usage

package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.alicloud.AlicloudFunctions;
import com.pulumi.alicloud.inputs.GetZonesArgs;
import com.pulumi.alicloud.ecs.EcsFunctions;
import com.pulumi.alicloud.ecs.inputs.GetInstanceTypesArgs;
import com.pulumi.alicloud.ecs.inputs.GetImagesArgs;
import com.pulumi.alicloud.vpc.Network;
import com.pulumi.alicloud.vpc.NetworkArgs;
import com.pulumi.alicloud.vpc.Switch;
import com.pulumi.alicloud.vpc.SwitchArgs;
import com.pulumi.alicloud.ecs.SecurityGroup;
import com.pulumi.alicloud.ecs.SecurityGroupArgs;
import com.pulumi.alicloud.ecs.Instance;
import com.pulumi.alicloud.ecs.InstanceArgs;
import com.pulumi.alicloud.ecs.EcsDisk;
import com.pulumi.alicloud.ecs.EcsDiskArgs;
import com.pulumi.alicloud.ecs.DiskAttachment;
import com.pulumi.alicloud.ecs.DiskAttachmentArgs;
import com.pulumi.alicloud.ecs.EcsSnapshotGroup;
import com.pulumi.alicloud.ecs.EcsSnapshotGroupArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
final var defaultZones = AlicloudFunctions.getZones(GetZonesArgs.builder()
.availableResourceCreation("Instance")
.availableDiskCategory("cloud_essd")
.build());
final var defaultInstanceTypes = EcsFunctions.getInstanceTypes(GetInstanceTypesArgs.builder()
.availabilityZone(defaultZones.applyValue(getZonesResult -> getZonesResult.zones()[0].id()))
.systemDiskCategory("cloud_essd")
.build());
final var defaultImages = EcsFunctions.getImages(GetImagesArgs.builder()
.owners("system")
.build());
var defaultNetwork = new Network("defaultNetwork", NetworkArgs.builder()
.vpcName("terraform-example")
.cidrBlock("172.17.3.0/24")
.build());
var defaultSwitch = new Switch("defaultSwitch", SwitchArgs.builder()
.vswitchName("terraform-example")
.cidrBlock("172.17.3.0/24")
.vpcId(defaultNetwork.id())
.zoneId(defaultZones.applyValue(getZonesResult -> getZonesResult.zones()[0].id()))
.build());
var defaultSecurityGroup = new SecurityGroup("defaultSecurityGroup", SecurityGroupArgs.builder()
.vpcId(defaultNetwork.id())
.build());
var defaultInstance = new Instance("defaultInstance", InstanceArgs.builder()
.availabilityZone(defaultZones.applyValue(getZonesResult -> getZonesResult.zones()[0].id()))
.instanceName("terraform-example")
.securityGroups(defaultSecurityGroup.id())
.vswitchId(defaultSwitch.id())
.instanceType(defaultInstanceTypes.applyValue(getInstanceTypesResult -> getInstanceTypesResult.instanceTypes()[0].id()))
.imageId(defaultImages.applyValue(getImagesResult -> getImagesResult.images()[0].id()))
.internetMaxBandwidthOut(10)
.build());
var defaultEcsDisk = new EcsDisk("defaultEcsDisk", EcsDiskArgs.builder()
.zoneId(defaultZones.applyValue(getZonesResult -> getZonesResult.zones()[0].id()))
.diskName("terraform-example")
.description("terraform-example")
.category("cloud_essd")
.size("30")
.build());
var defaultDiskAttachment = new DiskAttachment("defaultDiskAttachment", DiskAttachmentArgs.builder()
.diskId(defaultEcsDisk.id())
.instanceId(defaultInstance.id())
.build());
var defaultEcsSnapshotGroup = new EcsSnapshotGroup("defaultEcsSnapshotGroup", EcsSnapshotGroupArgs.builder()
.description("terraform-example")
.diskIds(defaultEcsDisk.id())
.snapshotGroupName("terraform-example")
.instanceId(defaultInstance.id())
.instantAccess(true)
.instantAccessRetentionDays(1)
.tags(Map.ofEntries(
Map.entry("Created", "TF"),
Map.entry("For", "Acceptance")
))
.build());
}
}

Import

ECS Snapshot Group can be imported using the id, e.g.

$ pulumi import alicloud:ecs/ecsSnapshotGroup:EcsSnapshotGroup example <id>

Properties

Link copied to clipboard
val description: Output<String>?

The description of the snapshot-consistent group. The description must be 2 to 256 characters in length and cannot start with http:// or https://.

Link copied to clipboard
val diskIds: Output<List<String>>?

The ID of disk for which to create snapshots. You can specify multiple disk IDs across instances with the same zone.

Link copied to clipboard
val excludeDiskIds: Output<List<String>>?

The ID of disk N for which you do not need to create snapshots. After this parameter is specified, the created snapshot-consistent group does not contain snapshots of the disk.

Link copied to clipboard
val id: Output<String>
Link copied to clipboard
val instanceId: Output<String>?

The ID of the instance.

Link copied to clipboard
val instantAccess: Output<Boolean>?

Specifies whether to enable the instant access feature.

Link copied to clipboard

Specify the number of days for which the instant access feature is available. Unit: days. Valid values: 1 to 65535.

Link copied to clipboard
val pulumiChildResources: Set<KotlinResource>
Link copied to clipboard
Link copied to clipboard
Link copied to clipboard
val resourceGroupId: Output<String>

The ID of the resource group to which the snapshot consistency group belongs.

Link copied to clipboard

The name of the snapshot-consistent group. The name must be 2 to 128 characters in length, and can contain letters, digits, periods (.), underscores (_), hyphens (-), and colons (:). It must start with a letter or a digit and cannot start with http:// or https://.

Link copied to clipboard
val status: Output<String>

The status of the resource.

Link copied to clipboard
val tags: Output<Map<String, Any>>?

A mapping of tags to assign to the snapshot group.

Link copied to clipboard
val urn: Output<String>