We recommend using Azure Native.
azure.compute.DiskPoolIscsiTarget
Explore with Pulumi AI
Manages an iSCSI Target.
!> Note: Azure are officially halting the preview of Azure Disk Pools, and it will not be made generally available. New customers will not be able to register the Microsoft.StoragePool resource provider on their subscription and deploy new Disk Pools. Existing subscriptions registered with Microsoft.StoragePool may continue to deploy and manage disk pools for the time being.
!> Note: Each Disk Pool can have a maximum of 1 iSCSI Target.
Example Usage
import * as pulumi from "@pulumi/pulumi";
import * as azure from "@pulumi/azure";
import * as azuread from "@pulumi/azuread";
const exampleResourceGroup = new azure.core.ResourceGroup("example", {
name: "example",
location: "West Europe",
});
const exampleVirtualNetwork = new azure.network.VirtualNetwork("example", {
name: "example-network",
resourceGroupName: exampleResourceGroup.name,
location: exampleResourceGroup.location,
addressSpaces: ["10.0.0.0/16"],
});
const exampleSubnet = new azure.network.Subnet("example", {
name: "example-subnet",
resourceGroupName: exampleResourceGroup.name,
virtualNetworkName: exampleVirtualNetwork.name,
addressPrefixes: ["10.0.0.0/24"],
delegations: [{
name: "diskspool",
serviceDelegation: {
actions: ["Microsoft.Network/virtualNetworks/read"],
name: "Microsoft.StoragePool/diskPools",
},
}],
});
const exampleDiskPool = new azure.compute.DiskPool("example", {
name: "example-pool",
resourceGroupName: exampleResourceGroup.name,
location: exampleResourceGroup.location,
subnetId: exampleSubnet.id,
zones: ["1"],
skuName: "Basic_B1",
});
const exampleManagedDisk = new azure.compute.ManagedDisk("example", {
name: "example-disk",
resourceGroupName: exampleResourceGroup.name,
location: exampleResourceGroup.location,
createOption: "Empty",
storageAccountType: "Premium_LRS",
diskSizeGb: 4,
maxShares: 2,
zone: "1",
});
const example = azuread.getServicePrincipal({
displayName: "StoragePool Resource Provider",
});
const roles = [
"Disk Pool Operator",
"Virtual Machine Contributor",
];
const exampleAssignment: azure.authorization.Assignment[] = [];
for (const range = {value: 0}; range.value < roles.length; range.value++) {
exampleAssignment.push(new azure.authorization.Assignment(`example-${range.value}`, {
principalId: example.then(example => example.id),
roleDefinitionName: roles[range.value],
scope: exampleManagedDisk.id,
}));
}
const exampleDiskPoolManagedDiskAttachment = new azure.compute.DiskPoolManagedDiskAttachment("example", {
diskPoolId: exampleDiskPool.id,
managedDiskId: exampleManagedDisk.id,
}, {
dependsOn: [exampleAssignment],
});
const exampleDiskPoolIscsiTarget = new azure.compute.DiskPoolIscsiTarget("example", {
name: "example",
aclMode: "Dynamic",
disksPoolId: exampleDiskPool.id,
targetIqn: "iqn.2021-11.com.microsoft:test",
}, {
dependsOn: [exampleDiskPoolManagedDiskAttachment],
});
import pulumi
import pulumi_azure as azure
import pulumi_azuread as azuread
example_resource_group = azure.core.ResourceGroup("example",
name="example",
location="West Europe")
example_virtual_network = azure.network.VirtualNetwork("example",
name="example-network",
resource_group_name=example_resource_group.name,
location=example_resource_group.location,
address_spaces=["10.0.0.0/16"])
example_subnet = azure.network.Subnet("example",
name="example-subnet",
resource_group_name=example_resource_group.name,
virtual_network_name=example_virtual_network.name,
address_prefixes=["10.0.0.0/24"],
delegations=[azure.network.SubnetDelegationArgs(
name="diskspool",
service_delegation=azure.network.SubnetDelegationServiceDelegationArgs(
actions=["Microsoft.Network/virtualNetworks/read"],
name="Microsoft.StoragePool/diskPools",
),
)])
example_disk_pool = azure.compute.DiskPool("example",
name="example-pool",
resource_group_name=example_resource_group.name,
location=example_resource_group.location,
subnet_id=example_subnet.id,
zones=["1"],
sku_name="Basic_B1")
example_managed_disk = azure.compute.ManagedDisk("example",
name="example-disk",
resource_group_name=example_resource_group.name,
location=example_resource_group.location,
create_option="Empty",
storage_account_type="Premium_LRS",
disk_size_gb=4,
max_shares=2,
zone="1")
example = azuread.get_service_principal(display_name="StoragePool Resource Provider")
roles = [
"Disk Pool Operator",
"Virtual Machine Contributor",
]
example_assignment = []
for range in [{"value": i} for i in range(0, len(roles))]:
example_assignment.append(azure.authorization.Assignment(f"example-{range['value']}",
principal_id=example.id,
role_definition_name=roles[range["value"]],
scope=example_managed_disk.id))
example_disk_pool_managed_disk_attachment = azure.compute.DiskPoolManagedDiskAttachment("example",
disk_pool_id=example_disk_pool.id,
managed_disk_id=example_managed_disk.id,
opts=pulumi.ResourceOptions(depends_on=[example_assignment]))
example_disk_pool_iscsi_target = azure.compute.DiskPoolIscsiTarget("example",
name="example",
acl_mode="Dynamic",
disks_pool_id=example_disk_pool.id,
target_iqn="iqn.2021-11.com.microsoft:test",
opts=pulumi.ResourceOptions(depends_on=[example_disk_pool_managed_disk_attachment]))
package main
import (
"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/authorization"
"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/compute"
"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/core"
"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/network"
"github.com/pulumi/pulumi-azuread/sdk/v5/go/azuread"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
exampleResourceGroup, err := core.NewResourceGroup(ctx, "example", &core.ResourceGroupArgs{
Name: pulumi.String("example"),
Location: pulumi.String("West Europe"),
})
if err != nil {
return err
}
exampleVirtualNetwork, err := network.NewVirtualNetwork(ctx, "example", &network.VirtualNetworkArgs{
Name: pulumi.String("example-network"),
ResourceGroupName: exampleResourceGroup.Name,
Location: exampleResourceGroup.Location,
AddressSpaces: pulumi.StringArray{
pulumi.String("10.0.0.0/16"),
},
})
if err != nil {
return err
}
exampleSubnet, err := network.NewSubnet(ctx, "example", &network.SubnetArgs{
Name: pulumi.String("example-subnet"),
ResourceGroupName: exampleResourceGroup.Name,
VirtualNetworkName: exampleVirtualNetwork.Name,
AddressPrefixes: pulumi.StringArray{
pulumi.String("10.0.0.0/24"),
},
Delegations: network.SubnetDelegationArray{
&network.SubnetDelegationArgs{
Name: pulumi.String("diskspool"),
ServiceDelegation: &network.SubnetDelegationServiceDelegationArgs{
Actions: pulumi.StringArray{
pulumi.String("Microsoft.Network/virtualNetworks/read"),
},
Name: pulumi.String("Microsoft.StoragePool/diskPools"),
},
},
},
})
if err != nil {
return err
}
exampleDiskPool, err := compute.NewDiskPool(ctx, "example", &compute.DiskPoolArgs{
Name: pulumi.String("example-pool"),
ResourceGroupName: exampleResourceGroup.Name,
Location: exampleResourceGroup.Location,
SubnetId: exampleSubnet.ID(),
Zones: pulumi.StringArray{
pulumi.String("1"),
},
SkuName: pulumi.String("Basic_B1"),
})
if err != nil {
return err
}
exampleManagedDisk, err := compute.NewManagedDisk(ctx, "example", &compute.ManagedDiskArgs{
Name: pulumi.String("example-disk"),
ResourceGroupName: exampleResourceGroup.Name,
Location: exampleResourceGroup.Location,
CreateOption: pulumi.String("Empty"),
StorageAccountType: pulumi.String("Premium_LRS"),
DiskSizeGb: pulumi.Int(4),
MaxShares: pulumi.Int(2),
Zone: pulumi.String("1"),
})
if err != nil {
return err
}
example, err := azuread.LookupServicePrincipal(ctx, &azuread.LookupServicePrincipalArgs{
DisplayName: pulumi.StringRef("StoragePool Resource Provider"),
}, nil)
if err != nil {
return err
}
roles := []string{
"Disk Pool Operator",
"Virtual Machine Contributor",
}
var exampleAssignment []*authorization.Assignment
for index := 0; index < len(roles); index++ {
key0 := index
val0 := index
__res, err := authorization.NewAssignment(ctx, fmt.Sprintf("example-%v", key0), &authorization.AssignmentArgs{
PrincipalId: pulumi.String(example.Id),
RoleDefinitionName: roles[val0],
Scope: exampleManagedDisk.ID(),
})
if err != nil {
return err
}
exampleAssignment = append(exampleAssignment, __res)
}
exampleDiskPoolManagedDiskAttachment, err := compute.NewDiskPoolManagedDiskAttachment(ctx, "example", &compute.DiskPoolManagedDiskAttachmentArgs{
DiskPoolId: exampleDiskPool.ID(),
ManagedDiskId: exampleManagedDisk.ID(),
}, pulumi.DependsOn([]pulumi.Resource{
exampleAssignment,
}))
if err != nil {
return err
}
_, err = compute.NewDiskPoolIscsiTarget(ctx, "example", &compute.DiskPoolIscsiTargetArgs{
Name: pulumi.String("example"),
AclMode: pulumi.String("Dynamic"),
DisksPoolId: exampleDiskPool.ID(),
TargetIqn: pulumi.String("iqn.2021-11.com.microsoft:test"),
}, pulumi.DependsOn([]pulumi.Resource{
exampleDiskPoolManagedDiskAttachment,
}))
if err != nil {
return err
}
return nil
})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Azure = Pulumi.Azure;
using AzureAD = Pulumi.AzureAD;
return await Deployment.RunAsync(() =>
{
var exampleResourceGroup = new Azure.Core.ResourceGroup("example", new()
{
Name = "example",
Location = "West Europe",
});
var exampleVirtualNetwork = new Azure.Network.VirtualNetwork("example", new()
{
Name = "example-network",
ResourceGroupName = exampleResourceGroup.Name,
Location = exampleResourceGroup.Location,
AddressSpaces = new[]
{
"10.0.0.0/16",
},
});
var exampleSubnet = new Azure.Network.Subnet("example", new()
{
Name = "example-subnet",
ResourceGroupName = exampleResourceGroup.Name,
VirtualNetworkName = exampleVirtualNetwork.Name,
AddressPrefixes = new[]
{
"10.0.0.0/24",
},
Delegations = new[]
{
new Azure.Network.Inputs.SubnetDelegationArgs
{
Name = "diskspool",
ServiceDelegation = new Azure.Network.Inputs.SubnetDelegationServiceDelegationArgs
{
Actions = new[]
{
"Microsoft.Network/virtualNetworks/read",
},
Name = "Microsoft.StoragePool/diskPools",
},
},
},
});
var exampleDiskPool = new Azure.Compute.DiskPool("example", new()
{
Name = "example-pool",
ResourceGroupName = exampleResourceGroup.Name,
Location = exampleResourceGroup.Location,
SubnetId = exampleSubnet.Id,
Zones = new[]
{
"1",
},
SkuName = "Basic_B1",
});
var exampleManagedDisk = new Azure.Compute.ManagedDisk("example", new()
{
Name = "example-disk",
ResourceGroupName = exampleResourceGroup.Name,
Location = exampleResourceGroup.Location,
CreateOption = "Empty",
StorageAccountType = "Premium_LRS",
DiskSizeGb = 4,
MaxShares = 2,
Zone = "1",
});
var example = AzureAD.GetServicePrincipal.Invoke(new()
{
DisplayName = "StoragePool Resource Provider",
});
var roles = new[]
{
"Disk Pool Operator",
"Virtual Machine Contributor",
};
var exampleAssignment = new List<Azure.Authorization.Assignment>();
for (var rangeIndex = 0; rangeIndex < roles.Length; rangeIndex++)
{
var range = new { Value = rangeIndex };
exampleAssignment.Add(new Azure.Authorization.Assignment($"example-{range.Value}", new()
{
PrincipalId = example.Apply(getServicePrincipalResult => getServicePrincipalResult.Id),
RoleDefinitionName = roles[range.Value],
Scope = exampleManagedDisk.Id,
}));
}
var exampleDiskPoolManagedDiskAttachment = new Azure.Compute.DiskPoolManagedDiskAttachment("example", new()
{
DiskPoolId = exampleDiskPool.Id,
ManagedDiskId = exampleManagedDisk.Id,
}, new CustomResourceOptions
{
DependsOn =
{
exampleAssignment,
},
});
var exampleDiskPoolIscsiTarget = new Azure.Compute.DiskPoolIscsiTarget("example", new()
{
Name = "example",
AclMode = "Dynamic",
DisksPoolId = exampleDiskPool.Id,
TargetIqn = "iqn.2021-11.com.microsoft:test",
}, new CustomResourceOptions
{
DependsOn =
{
exampleDiskPoolManagedDiskAttachment,
},
});
});
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.azure.core.ResourceGroup;
import com.pulumi.azure.core.ResourceGroupArgs;
import com.pulumi.azure.network.VirtualNetwork;
import com.pulumi.azure.network.VirtualNetworkArgs;
import com.pulumi.azure.network.Subnet;
import com.pulumi.azure.network.SubnetArgs;
import com.pulumi.azure.network.inputs.SubnetDelegationArgs;
import com.pulumi.azure.network.inputs.SubnetDelegationServiceDelegationArgs;
import com.pulumi.azure.compute.DiskPool;
import com.pulumi.azure.compute.DiskPoolArgs;
import com.pulumi.azure.compute.ManagedDisk;
import com.pulumi.azure.compute.ManagedDiskArgs;
import com.pulumi.azuread.AzureadFunctions;
import com.pulumi.azuread.inputs.GetServicePrincipalArgs;
import com.pulumi.azure.authorization.Assignment;
import com.pulumi.azure.authorization.AssignmentArgs;
import com.pulumi.azure.compute.DiskPoolManagedDiskAttachment;
import com.pulumi.azure.compute.DiskPoolManagedDiskAttachmentArgs;
import com.pulumi.azure.compute.DiskPoolIscsiTarget;
import com.pulumi.azure.compute.DiskPoolIscsiTargetArgs;
import com.pulumi.codegen.internal.KeyedValue;
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) {
var exampleResourceGroup = new ResourceGroup("exampleResourceGroup", ResourceGroupArgs.builder()
.name("example")
.location("West Europe")
.build());
var exampleVirtualNetwork = new VirtualNetwork("exampleVirtualNetwork", VirtualNetworkArgs.builder()
.name("example-network")
.resourceGroupName(exampleResourceGroup.name())
.location(exampleResourceGroup.location())
.addressSpaces("10.0.0.0/16")
.build());
var exampleSubnet = new Subnet("exampleSubnet", SubnetArgs.builder()
.name("example-subnet")
.resourceGroupName(exampleResourceGroup.name())
.virtualNetworkName(exampleVirtualNetwork.name())
.addressPrefixes("10.0.0.0/24")
.delegations(SubnetDelegationArgs.builder()
.name("diskspool")
.serviceDelegation(SubnetDelegationServiceDelegationArgs.builder()
.actions("Microsoft.Network/virtualNetworks/read")
.name("Microsoft.StoragePool/diskPools")
.build())
.build())
.build());
var exampleDiskPool = new DiskPool("exampleDiskPool", DiskPoolArgs.builder()
.name("example-pool")
.resourceGroupName(exampleResourceGroup.name())
.location(exampleResourceGroup.location())
.subnetId(exampleSubnet.id())
.zones("1")
.skuName("Basic_B1")
.build());
var exampleManagedDisk = new ManagedDisk("exampleManagedDisk", ManagedDiskArgs.builder()
.name("example-disk")
.resourceGroupName(exampleResourceGroup.name())
.location(exampleResourceGroup.location())
.createOption("Empty")
.storageAccountType("Premium_LRS")
.diskSizeGb(4)
.maxShares(2)
.zone("1")
.build());
final var example = AzureadFunctions.getServicePrincipal(GetServicePrincipalArgs.builder()
.displayName("StoragePool Resource Provider")
.build());
final var roles =
"Disk Pool Operator",
"Virtual Machine Contributor";
for (var i = 0; i < roles.length(); i++) {
new Assignment("exampleAssignment-" + i, AssignmentArgs.builder()
.principalId(example.applyValue(getServicePrincipalResult -> getServicePrincipalResult.id()))
.roleDefinitionName(roles[range.value()])
.scope(exampleManagedDisk.id())
.build());
}
var exampleDiskPoolManagedDiskAttachment = new DiskPoolManagedDiskAttachment("exampleDiskPoolManagedDiskAttachment", DiskPoolManagedDiskAttachmentArgs.builder()
.diskPoolId(exampleDiskPool.id())
.managedDiskId(exampleManagedDisk.id())
.build(), CustomResourceOptions.builder()
.dependsOn(exampleAssignment)
.build());
var exampleDiskPoolIscsiTarget = new DiskPoolIscsiTarget("exampleDiskPoolIscsiTarget", DiskPoolIscsiTargetArgs.builder()
.name("example")
.aclMode("Dynamic")
.disksPoolId(exampleDiskPool.id())
.targetIqn("iqn.2021-11.com.microsoft:test")
.build(), CustomResourceOptions.builder()
.dependsOn(exampleDiskPoolManagedDiskAttachment)
.build());
}
}
Coming soon!
Create DiskPoolIscsiTarget Resource
Resources are created with functions called constructors. To learn more about declaring and configuring resources, see Resources.
Constructor syntax
new DiskPoolIscsiTarget(name: string, args: DiskPoolIscsiTargetArgs, opts?: CustomResourceOptions);
@overload
def DiskPoolIscsiTarget(resource_name: str,
args: DiskPoolIscsiTargetArgs,
opts: Optional[ResourceOptions] = None)
@overload
def DiskPoolIscsiTarget(resource_name: str,
opts: Optional[ResourceOptions] = None,
acl_mode: Optional[str] = None,
disks_pool_id: Optional[str] = None,
name: Optional[str] = None,
target_iqn: Optional[str] = None)
func NewDiskPoolIscsiTarget(ctx *Context, name string, args DiskPoolIscsiTargetArgs, opts ...ResourceOption) (*DiskPoolIscsiTarget, error)
public DiskPoolIscsiTarget(string name, DiskPoolIscsiTargetArgs args, CustomResourceOptions? opts = null)
public DiskPoolIscsiTarget(String name, DiskPoolIscsiTargetArgs args)
public DiskPoolIscsiTarget(String name, DiskPoolIscsiTargetArgs args, CustomResourceOptions options)
type: azure:compute:DiskPoolIscsiTarget
properties: # The arguments to resource properties.
options: # Bag of options to control resource's behavior.
Parameters
- name string
- The unique name of the resource.
- args DiskPoolIscsiTargetArgs
- The arguments to resource properties.
- opts CustomResourceOptions
- Bag of options to control resource's behavior.
- resource_name str
- The unique name of the resource.
- args DiskPoolIscsiTargetArgs
- The arguments to resource properties.
- opts ResourceOptions
- Bag of options to control resource's behavior.
- ctx Context
- Context object for the current deployment.
- name string
- The unique name of the resource.
- args DiskPoolIscsiTargetArgs
- The arguments to resource properties.
- opts ResourceOption
- Bag of options to control resource's behavior.
- name string
- The unique name of the resource.
- args DiskPoolIscsiTargetArgs
- The arguments to resource properties.
- opts CustomResourceOptions
- Bag of options to control resource's behavior.
- name String
- The unique name of the resource.
- args DiskPoolIscsiTargetArgs
- The arguments to resource properties.
- options CustomResourceOptions
- Bag of options to control resource's behavior.
Constructor example
The following reference example uses placeholder values for all input properties.
var diskPoolIscsiTargetResource = new Azure.Compute.DiskPoolIscsiTarget("diskPoolIscsiTargetResource", new()
{
AclMode = "string",
DisksPoolId = "string",
Name = "string",
TargetIqn = "string",
});
example, err := compute.NewDiskPoolIscsiTarget(ctx, "diskPoolIscsiTargetResource", &compute.DiskPoolIscsiTargetArgs{
AclMode: pulumi.String("string"),
DisksPoolId: pulumi.String("string"),
Name: pulumi.String("string"),
TargetIqn: pulumi.String("string"),
})
var diskPoolIscsiTargetResource = new DiskPoolIscsiTarget("diskPoolIscsiTargetResource", DiskPoolIscsiTargetArgs.builder()
.aclMode("string")
.disksPoolId("string")
.name("string")
.targetIqn("string")
.build());
disk_pool_iscsi_target_resource = azure.compute.DiskPoolIscsiTarget("diskPoolIscsiTargetResource",
acl_mode="string",
disks_pool_id="string",
name="string",
target_iqn="string")
const diskPoolIscsiTargetResource = new azure.compute.DiskPoolIscsiTarget("diskPoolIscsiTargetResource", {
aclMode: "string",
disksPoolId: "string",
name: "string",
targetIqn: "string",
});
type: azure:compute:DiskPoolIscsiTarget
properties:
aclMode: string
disksPoolId: string
name: string
targetIqn: string
DiskPoolIscsiTarget Resource Properties
To learn more about resource properties and how to use them, see Inputs and Outputs in the Architecture and Concepts docs.
Inputs
The DiskPoolIscsiTarget resource accepts the following input properties:
- Acl
Mode string - Mode for Target connectivity. The only supported value is
Dynamic
for now. Changing this forces a new iSCSI Target to be created. - Disks
Pool stringId - The ID of the Disk Pool. Changing this forces a new iSCSI Target to be created.
- Name string
- The name of the iSCSI Target. The name can only contain lowercase letters, numbers, periods, or hyphens, and length should between [5-223]. Changing this forces a new iSCSI Target to be created.
- Target
Iqn string - ISCSI Target IQN (iSCSI Qualified Name); example:
iqn.2005-03.org.iscsi:server
. IQN should follow the formatiqn.yyyy-mm.<abc>.<pqr>[:xyz]
; supported characters include alphanumeric characters in lower case, hyphen, dot and colon, and the length should between4
and223
. Changing this forces a new iSCSI Target to be created.
- Acl
Mode string - Mode for Target connectivity. The only supported value is
Dynamic
for now. Changing this forces a new iSCSI Target to be created. - Disks
Pool stringId - The ID of the Disk Pool. Changing this forces a new iSCSI Target to be created.
- Name string
- The name of the iSCSI Target. The name can only contain lowercase letters, numbers, periods, or hyphens, and length should between [5-223]. Changing this forces a new iSCSI Target to be created.
- Target
Iqn string - ISCSI Target IQN (iSCSI Qualified Name); example:
iqn.2005-03.org.iscsi:server
. IQN should follow the formatiqn.yyyy-mm.<abc>.<pqr>[:xyz]
; supported characters include alphanumeric characters in lower case, hyphen, dot and colon, and the length should between4
and223
. Changing this forces a new iSCSI Target to be created.
- acl
Mode String - Mode for Target connectivity. The only supported value is
Dynamic
for now. Changing this forces a new iSCSI Target to be created. - disks
Pool StringId - The ID of the Disk Pool. Changing this forces a new iSCSI Target to be created.
- name String
- The name of the iSCSI Target. The name can only contain lowercase letters, numbers, periods, or hyphens, and length should between [5-223]. Changing this forces a new iSCSI Target to be created.
- target
Iqn String - ISCSI Target IQN (iSCSI Qualified Name); example:
iqn.2005-03.org.iscsi:server
. IQN should follow the formatiqn.yyyy-mm.<abc>.<pqr>[:xyz]
; supported characters include alphanumeric characters in lower case, hyphen, dot and colon, and the length should between4
and223
. Changing this forces a new iSCSI Target to be created.
- acl
Mode string - Mode for Target connectivity. The only supported value is
Dynamic
for now. Changing this forces a new iSCSI Target to be created. - disks
Pool stringId - The ID of the Disk Pool. Changing this forces a new iSCSI Target to be created.
- name string
- The name of the iSCSI Target. The name can only contain lowercase letters, numbers, periods, or hyphens, and length should between [5-223]. Changing this forces a new iSCSI Target to be created.
- target
Iqn string - ISCSI Target IQN (iSCSI Qualified Name); example:
iqn.2005-03.org.iscsi:server
. IQN should follow the formatiqn.yyyy-mm.<abc>.<pqr>[:xyz]
; supported characters include alphanumeric characters in lower case, hyphen, dot and colon, and the length should between4
and223
. Changing this forces a new iSCSI Target to be created.
- acl_
mode str - Mode for Target connectivity. The only supported value is
Dynamic
for now. Changing this forces a new iSCSI Target to be created. - disks_
pool_ strid - The ID of the Disk Pool. Changing this forces a new iSCSI Target to be created.
- name str
- The name of the iSCSI Target. The name can only contain lowercase letters, numbers, periods, or hyphens, and length should between [5-223]. Changing this forces a new iSCSI Target to be created.
- target_
iqn str - ISCSI Target IQN (iSCSI Qualified Name); example:
iqn.2005-03.org.iscsi:server
. IQN should follow the formatiqn.yyyy-mm.<abc>.<pqr>[:xyz]
; supported characters include alphanumeric characters in lower case, hyphen, dot and colon, and the length should between4
and223
. Changing this forces a new iSCSI Target to be created.
- acl
Mode String - Mode for Target connectivity. The only supported value is
Dynamic
for now. Changing this forces a new iSCSI Target to be created. - disks
Pool StringId - The ID of the Disk Pool. Changing this forces a new iSCSI Target to be created.
- name String
- The name of the iSCSI Target. The name can only contain lowercase letters, numbers, periods, or hyphens, and length should between [5-223]. Changing this forces a new iSCSI Target to be created.
- target
Iqn String - ISCSI Target IQN (iSCSI Qualified Name); example:
iqn.2005-03.org.iscsi:server
. IQN should follow the formatiqn.yyyy-mm.<abc>.<pqr>[:xyz]
; supported characters include alphanumeric characters in lower case, hyphen, dot and colon, and the length should between4
and223
. Changing this forces a new iSCSI Target to be created.
Outputs
All input properties are implicitly available as output properties. Additionally, the DiskPoolIscsiTarget resource produces the following output properties:
Look up Existing DiskPoolIscsiTarget Resource
Get an existing DiskPoolIscsiTarget resource’s state with the given name, ID, and optional extra properties used to qualify the lookup.
public static get(name: string, id: Input<ID>, state?: DiskPoolIscsiTargetState, opts?: CustomResourceOptions): DiskPoolIscsiTarget
@staticmethod
def get(resource_name: str,
id: str,
opts: Optional[ResourceOptions] = None,
acl_mode: Optional[str] = None,
disks_pool_id: Optional[str] = None,
endpoints: Optional[Sequence[str]] = None,
name: Optional[str] = None,
port: Optional[int] = None,
target_iqn: Optional[str] = None) -> DiskPoolIscsiTarget
func GetDiskPoolIscsiTarget(ctx *Context, name string, id IDInput, state *DiskPoolIscsiTargetState, opts ...ResourceOption) (*DiskPoolIscsiTarget, error)
public static DiskPoolIscsiTarget Get(string name, Input<string> id, DiskPoolIscsiTargetState? state, CustomResourceOptions? opts = null)
public static DiskPoolIscsiTarget get(String name, Output<String> id, DiskPoolIscsiTargetState state, CustomResourceOptions options)
Resource lookup is not supported in YAML
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- resource_name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- Acl
Mode string - Mode for Target connectivity. The only supported value is
Dynamic
for now. Changing this forces a new iSCSI Target to be created. - Disks
Pool stringId - The ID of the Disk Pool. Changing this forces a new iSCSI Target to be created.
- Endpoints List<string>
- List of private IPv4 addresses to connect to the iSCSI Target.
- Name string
- The name of the iSCSI Target. The name can only contain lowercase letters, numbers, periods, or hyphens, and length should between [5-223]. Changing this forces a new iSCSI Target to be created.
- Port int
- The port used by iSCSI Target portal group.
- Target
Iqn string - ISCSI Target IQN (iSCSI Qualified Name); example:
iqn.2005-03.org.iscsi:server
. IQN should follow the formatiqn.yyyy-mm.<abc>.<pqr>[:xyz]
; supported characters include alphanumeric characters in lower case, hyphen, dot and colon, and the length should between4
and223
. Changing this forces a new iSCSI Target to be created.
- Acl
Mode string - Mode for Target connectivity. The only supported value is
Dynamic
for now. Changing this forces a new iSCSI Target to be created. - Disks
Pool stringId - The ID of the Disk Pool. Changing this forces a new iSCSI Target to be created.
- Endpoints []string
- List of private IPv4 addresses to connect to the iSCSI Target.
- Name string
- The name of the iSCSI Target. The name can only contain lowercase letters, numbers, periods, or hyphens, and length should between [5-223]. Changing this forces a new iSCSI Target to be created.
- Port int
- The port used by iSCSI Target portal group.
- Target
Iqn string - ISCSI Target IQN (iSCSI Qualified Name); example:
iqn.2005-03.org.iscsi:server
. IQN should follow the formatiqn.yyyy-mm.<abc>.<pqr>[:xyz]
; supported characters include alphanumeric characters in lower case, hyphen, dot and colon, and the length should between4
and223
. Changing this forces a new iSCSI Target to be created.
- acl
Mode String - Mode for Target connectivity. The only supported value is
Dynamic
for now. Changing this forces a new iSCSI Target to be created. - disks
Pool StringId - The ID of the Disk Pool. Changing this forces a new iSCSI Target to be created.
- endpoints List<String>
- List of private IPv4 addresses to connect to the iSCSI Target.
- name String
- The name of the iSCSI Target. The name can only contain lowercase letters, numbers, periods, or hyphens, and length should between [5-223]. Changing this forces a new iSCSI Target to be created.
- port Integer
- The port used by iSCSI Target portal group.
- target
Iqn String - ISCSI Target IQN (iSCSI Qualified Name); example:
iqn.2005-03.org.iscsi:server
. IQN should follow the formatiqn.yyyy-mm.<abc>.<pqr>[:xyz]
; supported characters include alphanumeric characters in lower case, hyphen, dot and colon, and the length should between4
and223
. Changing this forces a new iSCSI Target to be created.
- acl
Mode string - Mode for Target connectivity. The only supported value is
Dynamic
for now. Changing this forces a new iSCSI Target to be created. - disks
Pool stringId - The ID of the Disk Pool. Changing this forces a new iSCSI Target to be created.
- endpoints string[]
- List of private IPv4 addresses to connect to the iSCSI Target.
- name string
- The name of the iSCSI Target. The name can only contain lowercase letters, numbers, periods, or hyphens, and length should between [5-223]. Changing this forces a new iSCSI Target to be created.
- port number
- The port used by iSCSI Target portal group.
- target
Iqn string - ISCSI Target IQN (iSCSI Qualified Name); example:
iqn.2005-03.org.iscsi:server
. IQN should follow the formatiqn.yyyy-mm.<abc>.<pqr>[:xyz]
; supported characters include alphanumeric characters in lower case, hyphen, dot and colon, and the length should between4
and223
. Changing this forces a new iSCSI Target to be created.
- acl_
mode str - Mode for Target connectivity. The only supported value is
Dynamic
for now. Changing this forces a new iSCSI Target to be created. - disks_
pool_ strid - The ID of the Disk Pool. Changing this forces a new iSCSI Target to be created.
- endpoints Sequence[str]
- List of private IPv4 addresses to connect to the iSCSI Target.
- name str
- The name of the iSCSI Target. The name can only contain lowercase letters, numbers, periods, or hyphens, and length should between [5-223]. Changing this forces a new iSCSI Target to be created.
- port int
- The port used by iSCSI Target portal group.
- target_
iqn str - ISCSI Target IQN (iSCSI Qualified Name); example:
iqn.2005-03.org.iscsi:server
. IQN should follow the formatiqn.yyyy-mm.<abc>.<pqr>[:xyz]
; supported characters include alphanumeric characters in lower case, hyphen, dot and colon, and the length should between4
and223
. Changing this forces a new iSCSI Target to be created.
- acl
Mode String - Mode for Target connectivity. The only supported value is
Dynamic
for now. Changing this forces a new iSCSI Target to be created. - disks
Pool StringId - The ID of the Disk Pool. Changing this forces a new iSCSI Target to be created.
- endpoints List<String>
- List of private IPv4 addresses to connect to the iSCSI Target.
- name String
- The name of the iSCSI Target. The name can only contain lowercase letters, numbers, periods, or hyphens, and length should between [5-223]. Changing this forces a new iSCSI Target to be created.
- port Number
- The port used by iSCSI Target portal group.
- target
Iqn String - ISCSI Target IQN (iSCSI Qualified Name); example:
iqn.2005-03.org.iscsi:server
. IQN should follow the formatiqn.yyyy-mm.<abc>.<pqr>[:xyz]
; supported characters include alphanumeric characters in lower case, hyphen, dot and colon, and the length should between4
and223
. Changing this forces a new iSCSI Target to be created.
Import
iSCSI Targets can be imported using the resource id
, e.g.
$ pulumi import azure:compute/diskPoolIscsiTarget:DiskPoolIscsiTarget example /subscriptions/12345678-1234-9876-4563-123456789012/resourceGroups/group1/providers/Microsoft.StoragePool/diskPools/pool1/iscsiTargets/iscsiTarget1
To learn more about importing existing cloud resources, see Importing resources.
Package Details
- Repository
- Azure Classic pulumi/pulumi-azure
- License
- Apache-2.0
- Notes
- This Pulumi package is based on the
azurerm
Terraform Provider.