Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Bicep resource definition
The clusters resource type can be deployed with operations that target:
For a list of changed properties in each API version, see change log.
Resource format
To create a Microsoft.Kusto/clusters resource, add the following Bicep to your template.
resource symbolicname 'Microsoft.Kusto/clusters@2020-02-15' = {
  scope: resourceSymbolicName or scope
  identity: {
    type: 'string'
    userAssignedIdentities: {
      {customized property}: {}
    }
  }
  location: 'string'
  name: 'string'
  properties: {
    enableDiskEncryption: bool
    enablePurge: bool
    enableStreamingIngest: bool
    keyVaultProperties: {
      keyName: 'string'
      keyVaultUri: 'string'
      keyVersion: 'string'
    }
    languageExtensions: {
      value: [
        {
          languageExtensionName: 'string'
        }
      ]
    }
    optimizedAutoscale: {
      isEnabled: bool
      maximum: int
      minimum: int
      version: int
    }
    trustedExternalTenants: [
      {
        value: 'string'
      }
    ]
    virtualNetworkConfiguration: {
      dataManagementPublicIpId: 'string'
      enginePublicIpId: 'string'
      subnetId: 'string'
    }
  }
  sku: {
    capacity: int
    name: 'string'
    tier: 'string'
  }
  tags: {
    {customized property}: 'string'
  }
  zones: [
    'string'
  ]
}
Property Values
Microsoft.Kusto/clusters
| Name | Description | Value | 
|---|---|---|
| identity | The identity of the cluster, if configured. | Identity | 
| location | The geo-location where the resource lives | string (required) | 
| name | The resource name | string (required) | 
| properties | The cluster properties. | ClusterProperties | 
| scope | Use when creating a resource at a scope that is different than the deployment scope. | Set this property to the symbolic name of a resource to apply the extension resource. | 
| sku | The SKU of the cluster. | AzureSku (required) | 
| tags | Resource tags | Dictionary of tag names and values. See Tags in templates | 
| zones | The availability zones of the cluster. | string[] | 
AzureSku
| Name | Description | Value | 
|---|---|---|
| capacity | The number of instances of the cluster. | int | 
| name | SKU name. | 'Dev(No SLA)_Standard_D11_v2' 'Dev(No SLA)_Standard_E2a_v4' 'Standard_D11_v2' 'Standard_D12_v2' 'Standard_D13_v2' 'Standard_D14_v2' 'Standard_DS13_v2+1TB_PS' 'Standard_DS13_v2+2TB_PS' 'Standard_DS14_v2+3TB_PS' 'Standard_DS14_v2+4TB_PS' 'Standard_E16as_v4+3TB_PS' 'Standard_E16as_v4+4TB_PS' 'Standard_E16a_v4' 'Standard_E2a_v4' 'Standard_E4a_v4' 'Standard_E8as_v4+1TB_PS' 'Standard_E8as_v4+2TB_PS' 'Standard_E8a_v4' 'Standard_L16s' 'Standard_L4s' 'Standard_L8s' (required) | 
| tier | SKU tier. | 'Basic' 'Standard' (required) | 
ClusterProperties
| Name | Description | Value | 
|---|---|---|
| enableDiskEncryption | A boolean value that indicates if the cluster's disks are encrypted. | bool | 
| enablePurge | A boolean value that indicates if the purge operations are enabled. | bool | 
| enableStreamingIngest | A boolean value that indicates if the streaming ingest is enabled. | bool | 
| keyVaultProperties | KeyVault properties for the cluster encryption. | KeyVaultProperties | 
| languageExtensions | List of the cluster's language extensions. | LanguageExtensionsList | 
| optimizedAutoscale | Optimized auto scale definition. | OptimizedAutoscale | 
| trustedExternalTenants | The cluster's external tenants. | TrustedExternalTenant[] | 
| virtualNetworkConfiguration | Virtual network definition. | VirtualNetworkConfiguration | 
ComponentsSgqdofSchemasIdentityPropertiesUserassignedidentitiesAdditionalproperties
| Name | Description | Value | 
|---|
Identity
| Name | Description | Value | 
|---|---|---|
| type | The identity type. | 'None' 'SystemAssigned' (required) | 
| userAssignedIdentities | The list of user identities associated with the Kusto cluster. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. | IdentityUserAssignedIdentities | 
IdentityUserAssignedIdentities
| Name | Description | Value | 
|---|
KeyVaultProperties
| Name | Description | Value | 
|---|---|---|
| keyName | The name of the key vault key. | string (required) | 
| keyVaultUri | The Uri of the key vault. | string (required) | 
| keyVersion | The version of the key vault key. | string (required) | 
LanguageExtension
| Name | Description | Value | 
|---|---|---|
| languageExtensionName | The language extension name. | 'PYTHON' 'R' | 
LanguageExtensionsList
| Name | Description | Value | 
|---|---|---|
| value | The list of language extensions. | LanguageExtension[] | 
OptimizedAutoscale
| Name | Description | Value | 
|---|---|---|
| isEnabled | A boolean value that indicate if the optimized autoscale feature is enabled or not. | bool (required) | 
| maximum | Maximum allowed instances count. | int (required) | 
| minimum | Minimum allowed instances count. | int (required) | 
| version | The version of the template defined, for instance 1. | int (required) | 
TrackedResourceTags
| Name | Description | Value | 
|---|
TrustedExternalTenant
| Name | Description | Value | 
|---|---|---|
| value | GUID representing an external tenant. | string | 
VirtualNetworkConfiguration
| Name | Description | Value | 
|---|---|---|
| dataManagementPublicIpId | Data management's service public IP address resource id. | string (required) | 
| enginePublicIpId | Engine service's public IP address resource id. | string (required) | 
| subnetId | The subnet resource id. | string (required) | 
Usage Examples
Azure Verified Modules
The following Azure Verified Modules can be used to deploy this resource type.
| Module | Description | 
|---|---|
| Azure Data Explorer (Kusto) cluster | AVM Resource Module for Azure Data Explorer (Kusto) cluster | 
Azure Quickstart Samples
The following Azure Quickstart templates contain Bicep samples for deploying this resource type.
| Bicep File | Description | 
|---|---|
| Azure Digital Twins with Time Data History Connection | This template creates an Azure Digital Twins instance configured with a time series data history connection. In order to create a connection, other resources must be created such as an Event Hubs namespace, an event hub, Azure Data Explorer cluster, and a database. Data is sent to an event hub which eventually forwards the data to the Azure Data Explorer cluster. Data is stored in a database table in the cluster | 
| Create a database watcher | This sample creates a database watcher for Azure SQL and configures its data store, SQL targets, and managed private endpoints | 
| Deploy Azure Data Explorer DB with Cosmos DB connection | Deploy Azure Data Explorer DB with Cosmos DB connection. | 
| Deploy Azure Data Explorer db with Event Grid connection | Deploy Azure Data Explorer db with Event Grid connection. | 
| Deploy Azure Data Explorer db with Event Hub connection | Deploy Azure Data Explorer db with Event Hub connection. | 
| FinOps hub | This template creates a new FinOps hub instance, including Data Explorer, Data Lake storage, and Data Factory. | 
ARM template resource definition
The clusters resource type can be deployed with operations that target:
For a list of changed properties in each API version, see change log.
Resource format
To create a Microsoft.Kusto/clusters resource, add the following JSON to your template.
{
  "type": "Microsoft.Kusto/clusters",
  "apiVersion": "2020-02-15",
  "name": "string",
  "identity": {
    "type": "string",
    "userAssignedIdentities": {
      "{customized property}": {
      }
    }
  },
  "location": "string",
  "properties": {
    "enableDiskEncryption": "bool",
    "enablePurge": "bool",
    "enableStreamingIngest": "bool",
    "keyVaultProperties": {
      "keyName": "string",
      "keyVaultUri": "string",
      "keyVersion": "string"
    },
    "languageExtensions": {
      "value": [
        {
          "languageExtensionName": "string"
        }
      ]
    },
    "optimizedAutoscale": {
      "isEnabled": "bool",
      "maximum": "int",
      "minimum": "int",
      "version": "int"
    },
    "trustedExternalTenants": [
      {
        "value": "string"
      }
    ],
    "virtualNetworkConfiguration": {
      "dataManagementPublicIpId": "string",
      "enginePublicIpId": "string",
      "subnetId": "string"
    }
  },
  "sku": {
    "capacity": "int",
    "name": "string",
    "tier": "string"
  },
  "tags": {
    "{customized property}": "string"
  },
  "zones": [ "string" ]
}
Property Values
Microsoft.Kusto/clusters
| Name | Description | Value | 
|---|---|---|
| apiVersion | The api version | '2020-02-15' | 
| identity | The identity of the cluster, if configured. | Identity | 
| location | The geo-location where the resource lives | string (required) | 
| name | The resource name | string (required) | 
| properties | The cluster properties. | ClusterProperties | 
| sku | The SKU of the cluster. | AzureSku (required) | 
| tags | Resource tags | Dictionary of tag names and values. See Tags in templates | 
| type | The resource type | 'Microsoft.Kusto/clusters' | 
| zones | The availability zones of the cluster. | string[] | 
AzureSku
| Name | Description | Value | 
|---|---|---|
| capacity | The number of instances of the cluster. | int | 
| name | SKU name. | 'Dev(No SLA)_Standard_D11_v2' 'Dev(No SLA)_Standard_E2a_v4' 'Standard_D11_v2' 'Standard_D12_v2' 'Standard_D13_v2' 'Standard_D14_v2' 'Standard_DS13_v2+1TB_PS' 'Standard_DS13_v2+2TB_PS' 'Standard_DS14_v2+3TB_PS' 'Standard_DS14_v2+4TB_PS' 'Standard_E16as_v4+3TB_PS' 'Standard_E16as_v4+4TB_PS' 'Standard_E16a_v4' 'Standard_E2a_v4' 'Standard_E4a_v4' 'Standard_E8as_v4+1TB_PS' 'Standard_E8as_v4+2TB_PS' 'Standard_E8a_v4' 'Standard_L16s' 'Standard_L4s' 'Standard_L8s' (required) | 
| tier | SKU tier. | 'Basic' 'Standard' (required) | 
ClusterProperties
| Name | Description | Value | 
|---|---|---|
| enableDiskEncryption | A boolean value that indicates if the cluster's disks are encrypted. | bool | 
| enablePurge | A boolean value that indicates if the purge operations are enabled. | bool | 
| enableStreamingIngest | A boolean value that indicates if the streaming ingest is enabled. | bool | 
| keyVaultProperties | KeyVault properties for the cluster encryption. | KeyVaultProperties | 
| languageExtensions | List of the cluster's language extensions. | LanguageExtensionsList | 
| optimizedAutoscale | Optimized auto scale definition. | OptimizedAutoscale | 
| trustedExternalTenants | The cluster's external tenants. | TrustedExternalTenant[] | 
| virtualNetworkConfiguration | Virtual network definition. | VirtualNetworkConfiguration | 
ComponentsSgqdofSchemasIdentityPropertiesUserassignedidentitiesAdditionalproperties
| Name | Description | Value | 
|---|
Identity
| Name | Description | Value | 
|---|---|---|
| type | The identity type. | 'None' 'SystemAssigned' (required) | 
| userAssignedIdentities | The list of user identities associated with the Kusto cluster. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. | IdentityUserAssignedIdentities | 
IdentityUserAssignedIdentities
| Name | Description | Value | 
|---|
KeyVaultProperties
| Name | Description | Value | 
|---|---|---|
| keyName | The name of the key vault key. | string (required) | 
| keyVaultUri | The Uri of the key vault. | string (required) | 
| keyVersion | The version of the key vault key. | string (required) | 
LanguageExtension
| Name | Description | Value | 
|---|---|---|
| languageExtensionName | The language extension name. | 'PYTHON' 'R' | 
LanguageExtensionsList
| Name | Description | Value | 
|---|---|---|
| value | The list of language extensions. | LanguageExtension[] | 
OptimizedAutoscale
| Name | Description | Value | 
|---|---|---|
| isEnabled | A boolean value that indicate if the optimized autoscale feature is enabled or not. | bool (required) | 
| maximum | Maximum allowed instances count. | int (required) | 
| minimum | Minimum allowed instances count. | int (required) | 
| version | The version of the template defined, for instance 1. | int (required) | 
TrackedResourceTags
| Name | Description | Value | 
|---|
TrustedExternalTenant
| Name | Description | Value | 
|---|---|---|
| value | GUID representing an external tenant. | string | 
VirtualNetworkConfiguration
| Name | Description | Value | 
|---|---|---|
| dataManagementPublicIpId | Data management's service public IP address resource id. | string (required) | 
| enginePublicIpId | Engine service's public IP address resource id. | string (required) | 
| subnetId | The subnet resource id. | string (required) | 
Usage Examples
Azure Quickstart Templates
The following Azure Quickstart templates deploy this resource type.
| Template | Description | 
|---|---|
| Azure Digital Twins with Time Data History Connection | This template creates an Azure Digital Twins instance configured with a time series data history connection. In order to create a connection, other resources must be created such as an Event Hubs namespace, an event hub, Azure Data Explorer cluster, and a database. Data is sent to an event hub which eventually forwards the data to the Azure Data Explorer cluster. Data is stored in a database table in the cluster | 
| Create a cluster a database | This template allows you to create a cluster and a database. | 
| Create a database watcher | This sample creates a database watcher for Azure SQL and configures its data store, SQL targets, and managed private endpoints | 
| Deploy Azure Data Explorer cluster into your VNet | This template allows you deploy a cluster into your VNet. | 
| Deploy Azure Data Explorer DB with Cosmos DB connection | Deploy Azure Data Explorer DB with Cosmos DB connection. | 
| Deploy Azure Data Explorer db with Event Grid connection | Deploy Azure Data Explorer db with Event Grid connection. | 
| Deploy Azure Data Explorer db with Event Hub connection | Deploy Azure Data Explorer db with Event Hub connection. | 
| FinOps hub | This template creates a new FinOps hub instance, including Data Explorer, Data Lake storage, and Data Factory. | 
Terraform (AzAPI provider) resource definition
The clusters resource type can be deployed with operations that target:
For a list of changed properties in each API version, see change log.
Resource format
To create a Microsoft.Kusto/clusters resource, add the following Terraform to your template.
resource "azapi_resource" "symbolicname" {
  type = "Microsoft.Kusto/clusters@2020-02-15"
  name = "string"
  parent_id = "string"
  identity {
    type = "string"
    identity_ids = [
      "string"
    ]
  }
  location = "string"
  tags = {
    {customized property} = "string"
  }
  body = {
    properties = {
      enableDiskEncryption = bool
      enablePurge = bool
      enableStreamingIngest = bool
      keyVaultProperties = {
        keyName = "string"
        keyVaultUri = "string"
        keyVersion = "string"
      }
      languageExtensions = {
        value = [
          {
            languageExtensionName = "string"
          }
        ]
      }
      optimizedAutoscale = {
        isEnabled = bool
        maximum = int
        minimum = int
        version = int
      }
      trustedExternalTenants = [
        {
          value = "string"
        }
      ]
      virtualNetworkConfiguration = {
        dataManagementPublicIpId = "string"
        enginePublicIpId = "string"
        subnetId = "string"
      }
    }
    sku = {
      capacity = int
      name = "string"
      tier = "string"
    }
    zones = [
      "string"
    ]
  }
}
Property Values
Microsoft.Kusto/clusters
| Name | Description | Value | 
|---|---|---|
| identity | The identity of the cluster, if configured. | Identity | 
| location | The geo-location where the resource lives | string (required) | 
| name | The resource name | string (required) | 
| parent_id | The ID of the resource to apply this extension resource to. | string (required) | 
| properties | The cluster properties. | ClusterProperties | 
| sku | The SKU of the cluster. | AzureSku (required) | 
| tags | Resource tags | Dictionary of tag names and values. | 
| type | The resource type | "Microsoft.Kusto/clusters@2020-02-15" | 
| zones | The availability zones of the cluster. | string[] | 
AzureSku
| Name | Description | Value | 
|---|---|---|
| capacity | The number of instances of the cluster. | int | 
| name | SKU name. | 'Dev(No SLA)_Standard_D11_v2' 'Dev(No SLA)_Standard_E2a_v4' 'Standard_D11_v2' 'Standard_D12_v2' 'Standard_D13_v2' 'Standard_D14_v2' 'Standard_DS13_v2+1TB_PS' 'Standard_DS13_v2+2TB_PS' 'Standard_DS14_v2+3TB_PS' 'Standard_DS14_v2+4TB_PS' 'Standard_E16as_v4+3TB_PS' 'Standard_E16as_v4+4TB_PS' 'Standard_E16a_v4' 'Standard_E2a_v4' 'Standard_E4a_v4' 'Standard_E8as_v4+1TB_PS' 'Standard_E8as_v4+2TB_PS' 'Standard_E8a_v4' 'Standard_L16s' 'Standard_L4s' 'Standard_L8s' (required) | 
| tier | SKU tier. | 'Basic' 'Standard' (required) | 
ClusterProperties
| Name | Description | Value | 
|---|---|---|
| enableDiskEncryption | A boolean value that indicates if the cluster's disks are encrypted. | bool | 
| enablePurge | A boolean value that indicates if the purge operations are enabled. | bool | 
| enableStreamingIngest | A boolean value that indicates if the streaming ingest is enabled. | bool | 
| keyVaultProperties | KeyVault properties for the cluster encryption. | KeyVaultProperties | 
| languageExtensions | List of the cluster's language extensions. | LanguageExtensionsList | 
| optimizedAutoscale | Optimized auto scale definition. | OptimizedAutoscale | 
| trustedExternalTenants | The cluster's external tenants. | TrustedExternalTenant[] | 
| virtualNetworkConfiguration | Virtual network definition. | VirtualNetworkConfiguration | 
ComponentsSgqdofSchemasIdentityPropertiesUserassignedidentitiesAdditionalproperties
| Name | Description | Value | 
|---|
Identity
| Name | Description | Value | 
|---|---|---|
| type | The identity type. | 'None' 'SystemAssigned' (required) | 
| userAssignedIdentities | The list of user identities associated with the Kusto cluster. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. | IdentityUserAssignedIdentities | 
IdentityUserAssignedIdentities
| Name | Description | Value | 
|---|
KeyVaultProperties
| Name | Description | Value | 
|---|---|---|
| keyName | The name of the key vault key. | string (required) | 
| keyVaultUri | The Uri of the key vault. | string (required) | 
| keyVersion | The version of the key vault key. | string (required) | 
LanguageExtension
| Name | Description | Value | 
|---|---|---|
| languageExtensionName | The language extension name. | 'PYTHON' 'R' | 
LanguageExtensionsList
| Name | Description | Value | 
|---|---|---|
| value | The list of language extensions. | LanguageExtension[] | 
OptimizedAutoscale
| Name | Description | Value | 
|---|---|---|
| isEnabled | A boolean value that indicate if the optimized autoscale feature is enabled or not. | bool (required) | 
| maximum | Maximum allowed instances count. | int (required) | 
| minimum | Minimum allowed instances count. | int (required) | 
| version | The version of the template defined, for instance 1. | int (required) | 
TrackedResourceTags
| Name | Description | Value | 
|---|
TrustedExternalTenant
| Name | Description | Value | 
|---|---|---|
| value | GUID representing an external tenant. | string | 
VirtualNetworkConfiguration
| Name | Description | Value | 
|---|---|---|
| dataManagementPublicIpId | Data management's service public IP address resource id. | string (required) | 
| enginePublicIpId | Engine service's public IP address resource id. | string (required) | 
| subnetId | The subnet resource id. | string (required) | 
Usage Examples
Terraform Samples
A basic example of deploying Kusto (also known as Azure Data Explorer) Cluster.
terraform {
  required_providers {
    azapi = {
      source = "Azure/azapi"
    }
  }
}
provider "azapi" {
  skip_provider_registration = false
}
variable "resource_name" {
  type    = string
  default = "acctest0001"
}
variable "location" {
  type    = string
  default = "westeurope"
}
resource "azapi_resource" "resourceGroup" {
  type     = "Microsoft.Resources/resourceGroups@2020-06-01"
  name     = var.resource_name
  location = var.location
}
resource "azapi_resource" "cluster" {
  type      = "Microsoft.Kusto/clusters@2023-05-02"
  parent_id = azapi_resource.resourceGroup.id
  name      = var.resource_name
  location  = var.location
  body = {
    properties = {
      enableAutoStop                = true
      enableDiskEncryption          = false
      enableDoubleEncryption        = false
      enablePurge                   = false
      enableStreamingIngest         = false
      engineType                    = "V2"
      publicIPType                  = "IPv4"
      publicNetworkAccess           = "Enabled"
      restrictOutboundNetworkAccess = "Disabled"
      trustedExternalTenants = [
      ]
    }
    sku = {
      capacity = 1
      name     = "Dev(No SLA)_Standard_D11_v2"
      tier     = "Basic"
    }
  }
  schema_validation_enabled = false
  response_export_values    = ["*"]
}
A basic example of deploying Kusto (also known as Azure Data Explorer) Cluster.
terraform {
  required_providers {
    azapi = {
      source = "Azure/azapi"
    }
  }
}
provider "azapi" {
  skip_provider_registration = false
}
variable "resource_name" {
  type    = string
  default = "acctest0001"
}
variable "location" {
  type    = string
  default = "westeurope"
}
resource "azapi_resource" "resourceGroup" {
  type     = "Microsoft.Resources/resourceGroups@2020-06-01"
  name     = var.resource_name
  location = var.location
}
resource "azapi_resource" "cluster" {
  type      = "Microsoft.Kusto/clusters@2023-05-02"
  parent_id = azapi_resource.resourceGroup.id
  name      = var.resource_name
  location  = var.location
  body = {
    properties = {
      enableAutoStop                = true
      enableDiskEncryption          = false
      enableDoubleEncryption        = false
      enablePurge                   = false
      enableStreamingIngest         = false
      engineType                    = "V2"
      publicIPType                  = "IPv4"
      publicNetworkAccess           = "Enabled"
      restrictOutboundNetworkAccess = "Disabled"
      trustedExternalTenants = [
      ]
    }
    sku = {
      capacity = 1
      name     = "Dev(No SLA)_Standard_D11_v2"
      tier     = "Basic"
    }
  }
  schema_validation_enabled = false
  response_export_values    = ["*"]
}
Azure Verified Modules
The following Azure Verified Modules can be used to deploy this resource type.
| Module | Description | 
|---|---|
| Kusto Clusters | AVM Resource Module for Kusto Clusters |