Volume Args
Example Usage
Registering a volume:
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.nomad.NomadFunctions;
import com.pulumi.nomad.inputs.GetPluginArgs;
import com.pulumi.nomad.Volume;
import com.pulumi.nomad.VolumeArgs;
import com.pulumi.nomad.inputs.VolumeCapabilityArgs;
import com.pulumi.nomad.inputs.VolumeMountOptionsArgs;
import com.pulumi.nomad.inputs.VolumeTopologyRequestArgs;
import com.pulumi.nomad.inputs.VolumeTopologyRequestRequiredArgs;
import com.pulumi.resources.CustomResourceOptions;
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 ebs = NomadFunctions.getPlugin(GetPluginArgs.builder()
.pluginId("aws-ebs0")
.waitForHealthy(true)
.build());
var mysqlVolume = new Volume("mysqlVolume", VolumeArgs.builder()
.type("csi")
.pluginId("aws-ebs0")
.volumeId("mysql_volume")
.externalId(module.hashistack().ebs_test_volume_id())
.capabilities(VolumeCapabilityArgs.builder()
.accessMode("single-node-writer")
.attachmentMode("file-system")
.build())
.mountOptions(VolumeMountOptionsArgs.builder()
.fsType("ext4")
.build())
.topologyRequest(VolumeTopologyRequestArgs.builder()
.required(VolumeTopologyRequestRequiredArgs.builder()
.topologies(
VolumeTopologyRequestRequiredTopologyArgs.builder()
.segments(Map.ofEntries(
Map.entry("rack", "R1"),
Map.entry("zone", "us-east-1a")
))
.build(),
VolumeTopologyRequestRequiredTopologyArgs.builder()
.segments(Map.of("rack", "R2"))
.build())
.build())
.build())
.build(), CustomResourceOptions.builder()
.dependsOn(ebs.applyValue(getPluginResult -> getPluginResult))
.build());
}
}
Constructors
Properties
(string: <optional>)
- Deprecated. Use capability
block instead. Defines whether a volume should be available concurrently. Possible values are:
(string: <otional>)
- Deprecated. Use capability
block instead. The storage API that will be used by the volume.
(``Capability``: <required>)
- Options for validating the capability of a volume.
(boolean: false)
- If true, the volume will be deregistered on destroy.
(string: <required>)
- The ID of the physical volume from the storage provider.
(block: <optional>)
Options for mounting block-device
volumes without a pre-formatted file system.
(map[string]string: <optional>)
- An optional key-value map of strings passed directly to the CSI plugin to configure the volume.
(``TopologyRequest``: <optional>)
- Specify locations (region, zone, rack, etc.) where the provisioned volume is accessible from.