Open Zfs Snapshot Args
data class OpenZfsSnapshotArgs(val name: Output<String>? = null, val tags: Output<Map<String, String>>? = null, val volumeId: Output<String>? = null) : ConvertibleToJava<OpenZfsSnapshotArgs>
Manages an Amazon FSx for OpenZFS volume. See the FSx OpenZFS User Guide for more information.
Example Usage
Root volume Example
import * as pulumi from "@pulumi/pulumi";
import * as aws from "@pulumi/aws";
const exampleOpenZfsFileSystem = new aws.fsx.OpenZfsFileSystem("example", {
storageCapacity: 64,
subnetIds: [exampleAwsSubnet.id],
deploymentType: "SINGLE_AZ_1",
throughputCapacity: 64,
});
const example = new aws.fsx.OpenZfsSnapshot("example", {
name: "example",
volumeId: exampleOpenZfsFileSystem.rootVolumeId,
});
Content copied to clipboard
import pulumi
import pulumi_aws as aws
example_open_zfs_file_system = aws.fsx.OpenZfsFileSystem("example",
storage_capacity=64,
subnet_ids=[example_aws_subnet["id"]],
deployment_type="SINGLE_AZ_1",
throughput_capacity=64)
example = aws.fsx.OpenZfsSnapshot("example",
name="example",
volume_id=example_open_zfs_file_system.root_volume_id)
Content copied to clipboard
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Aws = Pulumi.Aws;
return await Deployment.RunAsync(() =>
{
var exampleOpenZfsFileSystem = new Aws.Fsx.OpenZfsFileSystem("example", new()
{
StorageCapacity = 64,
SubnetIds = new[]
{
exampleAwsSubnet.Id,
},
DeploymentType = "SINGLE_AZ_1",
ThroughputCapacity = 64,
});
var example = new Aws.Fsx.OpenZfsSnapshot("example", new()
{
Name = "example",
VolumeId = exampleOpenZfsFileSystem.RootVolumeId,
});
});
Content copied to clipboard
package main
import (
"github.com/pulumi/pulumi-aws/sdk/v6/go/aws/fsx"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
exampleOpenZfsFileSystem, err := fsx.NewOpenZfsFileSystem(ctx, "example", &fsx.OpenZfsFileSystemArgs{
StorageCapacity: pulumi.Int(64),
SubnetIds: pulumi.StringArray{
exampleAwsSubnet.Id,
},
DeploymentType: pulumi.String("SINGLE_AZ_1"),
ThroughputCapacity: pulumi.Int(64),
})
if err != nil {
return err
}
_, err = fsx.NewOpenZfsSnapshot(ctx, "example", &fsx.OpenZfsSnapshotArgs{
Name: pulumi.String("example"),
VolumeId: exampleOpenZfsFileSystem.RootVolumeId,
})
if err != nil {
return err
}
return nil
})
}
Content copied to clipboard
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.aws.fsx.OpenZfsFileSystem;
import com.pulumi.aws.fsx.OpenZfsFileSystemArgs;
import com.pulumi.aws.fsx.OpenZfsSnapshot;
import com.pulumi.aws.fsx.OpenZfsSnapshotArgs;
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) {
var exampleOpenZfsFileSystem = new OpenZfsFileSystem("exampleOpenZfsFileSystem", OpenZfsFileSystemArgs.builder()
.storageCapacity(64)
.subnetIds(exampleAwsSubnet.id())
.deploymentType("SINGLE_AZ_1")
.throughputCapacity(64)
.build());
var example = new OpenZfsSnapshot("example", OpenZfsSnapshotArgs.builder()
.name("example")
.volumeId(exampleOpenZfsFileSystem.rootVolumeId())
.build());
}
}
Content copied to clipboard
resources:
example:
type: aws:fsx:OpenZfsSnapshot
properties:
name: example
volumeId: ${exampleOpenZfsFileSystem.rootVolumeId}
exampleOpenZfsFileSystem:
type: aws:fsx:OpenZfsFileSystem
name: example
properties:
storageCapacity: 64
subnetIds:
- ${exampleAwsSubnet.id}
deploymentType: SINGLE_AZ_1
throughputCapacity: 64
Content copied to clipboard
Child volume Example
import * as pulumi from "@pulumi/pulumi";
import * as aws from "@pulumi/aws";
const exampleOpenZfsFileSystem = new aws.fsx.OpenZfsFileSystem("example", {
storageCapacity: 64,
subnetIds: [exampleAwsSubnet.id],
deploymentType: "SINGLE_AZ_1",
throughputCapacity: 64,
});
const exampleOpenZfsVolume = new aws.fsx.OpenZfsVolume("example", {
name: "example",
parentVolumeId: exampleOpenZfsFileSystem.rootVolumeId,
});
const example = new aws.fsx.OpenZfsSnapshot("example", {
name: "example",
volumeId: exampleOpenZfsVolume.id,
});
Content copied to clipboard
import pulumi
import pulumi_aws as aws
example_open_zfs_file_system = aws.fsx.OpenZfsFileSystem("example",
storage_capacity=64,
subnet_ids=[example_aws_subnet["id"]],
deployment_type="SINGLE_AZ_1",
throughput_capacity=64)
example_open_zfs_volume = aws.fsx.OpenZfsVolume("example",
name="example",
parent_volume_id=example_open_zfs_file_system.root_volume_id)
example = aws.fsx.OpenZfsSnapshot("example",
name="example",
volume_id=example_open_zfs_volume.id)
Content copied to clipboard
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Aws = Pulumi.Aws;
return await Deployment.RunAsync(() =>
{
var exampleOpenZfsFileSystem = new Aws.Fsx.OpenZfsFileSystem("example", new()
{
StorageCapacity = 64,
SubnetIds = new[]
{
exampleAwsSubnet.Id,
},
DeploymentType = "SINGLE_AZ_1",
ThroughputCapacity = 64,
});
var exampleOpenZfsVolume = new Aws.Fsx.OpenZfsVolume("example", new()
{
Name = "example",
ParentVolumeId = exampleOpenZfsFileSystem.RootVolumeId,
});
var example = new Aws.Fsx.OpenZfsSnapshot("example", new()
{
Name = "example",
VolumeId = exampleOpenZfsVolume.Id,
});
});
Content copied to clipboard
package main
import (
"github.com/pulumi/pulumi-aws/sdk/v6/go/aws/fsx"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
exampleOpenZfsFileSystem, err := fsx.NewOpenZfsFileSystem(ctx, "example", &fsx.OpenZfsFileSystemArgs{
StorageCapacity: pulumi.Int(64),
SubnetIds: pulumi.StringArray{
exampleAwsSubnet.Id,
},
DeploymentType: pulumi.String("SINGLE_AZ_1"),
ThroughputCapacity: pulumi.Int(64),
})
if err != nil {
return err
}
exampleOpenZfsVolume, err := fsx.NewOpenZfsVolume(ctx, "example", &fsx.OpenZfsVolumeArgs{
Name: pulumi.String("example"),
ParentVolumeId: exampleOpenZfsFileSystem.RootVolumeId,
})
if err != nil {
return err
}
_, err = fsx.NewOpenZfsSnapshot(ctx, "example", &fsx.OpenZfsSnapshotArgs{
Name: pulumi.String("example"),
VolumeId: exampleOpenZfsVolume.ID(),
})
if err != nil {
return err
}
return nil
})
}
Content copied to clipboard
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.aws.fsx.OpenZfsFileSystem;
import com.pulumi.aws.fsx.OpenZfsFileSystemArgs;
import com.pulumi.aws.fsx.OpenZfsVolume;
import com.pulumi.aws.fsx.OpenZfsVolumeArgs;
import com.pulumi.aws.fsx.OpenZfsSnapshot;
import com.pulumi.aws.fsx.OpenZfsSnapshotArgs;
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) {
var exampleOpenZfsFileSystem = new OpenZfsFileSystem("exampleOpenZfsFileSystem", OpenZfsFileSystemArgs.builder()
.storageCapacity(64)
.subnetIds(exampleAwsSubnet.id())
.deploymentType("SINGLE_AZ_1")
.throughputCapacity(64)
.build());
var exampleOpenZfsVolume = new OpenZfsVolume("exampleOpenZfsVolume", OpenZfsVolumeArgs.builder()
.name("example")
.parentVolumeId(exampleOpenZfsFileSystem.rootVolumeId())
.build());
var example = new OpenZfsSnapshot("example", OpenZfsSnapshotArgs.builder()
.name("example")
.volumeId(exampleOpenZfsVolume.id())
.build());
}
}
Content copied to clipboard
resources:
example:
type: aws:fsx:OpenZfsSnapshot
properties:
name: example
volumeId: ${exampleOpenZfsVolume.id}
exampleOpenZfsVolume:
type: aws:fsx:OpenZfsVolume
name: example
properties:
name: example
parentVolumeId: ${exampleOpenZfsFileSystem.rootVolumeId}
exampleOpenZfsFileSystem:
type: aws:fsx:OpenZfsFileSystem
name: example
properties:
storageCapacity: 64
subnetIds:
- ${exampleAwsSubnet.id}
deploymentType: SINGLE_AZ_1
throughputCapacity: 64
Content copied to clipboard
Import
Using pulumi import
, import FSx OpenZFS snapshot using the id
. For example:
$ pulumi import aws:fsx/openZfsSnapshot:OpenZfsSnapshot example fs-543ab12b1ca672f33
Content copied to clipboard
Constructors
Properties
Link copied to clipboard
A map of tags to assign to the file system. If configured with a provider default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level. If you have set copy_tags_to_backups
to true, and you specify one or more tags, no existing file system tags are copied from the file system to the backup.