We recommend using Azure Native.
azure.appservice.Plan
Explore with Pulumi AI
Manages an App Service Plan component.
!> NOTE: This resource has been deprecated in version 5.0 of the provider and will be removed in version 6.0. Please use azure.appservice.ServicePlan resource instead.
Example Usage
Dedicated)
import * as pulumi from "@pulumi/pulumi";
import * as azure from "@pulumi/azure";
const example = new azure.core.ResourceGroup("example", {
    name: "api-rg-pro",
    location: "West Europe",
});
const examplePlan = new azure.appservice.Plan("example", {
    name: "api-appserviceplan-pro",
    location: example.location,
    resourceGroupName: example.name,
    sku: {
        tier: "Standard",
        size: "S1",
    },
});
import pulumi
import pulumi_azure as azure
example = azure.core.ResourceGroup("example",
    name="api-rg-pro",
    location="West Europe")
example_plan = azure.appservice.Plan("example",
    name="api-appserviceplan-pro",
    location=example.location,
    resource_group_name=example.name,
    sku={
        "tier": "Standard",
        "size": "S1",
    })
package main
import (
	"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/appservice"
	"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/core"
	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
	pulumi.Run(func(ctx *pulumi.Context) error {
		example, err := core.NewResourceGroup(ctx, "example", &core.ResourceGroupArgs{
			Name:     pulumi.String("api-rg-pro"),
			Location: pulumi.String("West Europe"),
		})
		if err != nil {
			return err
		}
		_, err = appservice.NewPlan(ctx, "example", &appservice.PlanArgs{
			Name:              pulumi.String("api-appserviceplan-pro"),
			Location:          example.Location,
			ResourceGroupName: example.Name,
			Sku: &appservice.PlanSkuArgs{
				Tier: pulumi.String("Standard"),
				Size: pulumi.String("S1"),
			},
		})
		if err != nil {
			return err
		}
		return nil
	})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Azure = Pulumi.Azure;
return await Deployment.RunAsync(() => 
{
    var example = new Azure.Core.ResourceGroup("example", new()
    {
        Name = "api-rg-pro",
        Location = "West Europe",
    });
    var examplePlan = new Azure.AppService.Plan("example", new()
    {
        Name = "api-appserviceplan-pro",
        Location = example.Location,
        ResourceGroupName = example.Name,
        Sku = new Azure.AppService.Inputs.PlanSkuArgs
        {
            Tier = "Standard",
            Size = "S1",
        },
    });
});
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.appservice.Plan;
import com.pulumi.azure.appservice.PlanArgs;
import com.pulumi.azure.appservice.inputs.PlanSkuArgs;
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 example = new ResourceGroup("example", ResourceGroupArgs.builder()
            .name("api-rg-pro")
            .location("West Europe")
            .build());
        var examplePlan = new Plan("examplePlan", PlanArgs.builder()
            .name("api-appserviceplan-pro")
            .location(example.location())
            .resourceGroupName(example.name())
            .sku(PlanSkuArgs.builder()
                .tier("Standard")
                .size("S1")
                .build())
            .build());
    }
}
resources:
  example:
    type: azure:core:ResourceGroup
    properties:
      name: api-rg-pro
      location: West Europe
  examplePlan:
    type: azure:appservice:Plan
    name: example
    properties:
      name: api-appserviceplan-pro
      location: ${example.location}
      resourceGroupName: ${example.name}
      sku:
        tier: Standard
        size: S1
Shared / Consumption Plan)
import * as pulumi from "@pulumi/pulumi";
import * as azure from "@pulumi/azure";
const example = new azure.core.ResourceGroup("example", {
    name: "api-rg-pro",
    location: "West Europe",
});
const examplePlan = new azure.appservice.Plan("example", {
    name: "api-appserviceplan-pro",
    location: example.location,
    resourceGroupName: example.name,
    kind: "FunctionApp",
    sku: {
        tier: "Dynamic",
        size: "Y1",
    },
});
import pulumi
import pulumi_azure as azure
example = azure.core.ResourceGroup("example",
    name="api-rg-pro",
    location="West Europe")
example_plan = azure.appservice.Plan("example",
    name="api-appserviceplan-pro",
    location=example.location,
    resource_group_name=example.name,
    kind="FunctionApp",
    sku={
        "tier": "Dynamic",
        "size": "Y1",
    })
package main
import (
	"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/appservice"
	"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/core"
	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
	pulumi.Run(func(ctx *pulumi.Context) error {
		example, err := core.NewResourceGroup(ctx, "example", &core.ResourceGroupArgs{
			Name:     pulumi.String("api-rg-pro"),
			Location: pulumi.String("West Europe"),
		})
		if err != nil {
			return err
		}
		_, err = appservice.NewPlan(ctx, "example", &appservice.PlanArgs{
			Name:              pulumi.String("api-appserviceplan-pro"),
			Location:          example.Location,
			ResourceGroupName: example.Name,
			Kind:              pulumi.Any("FunctionApp"),
			Sku: &appservice.PlanSkuArgs{
				Tier: pulumi.String("Dynamic"),
				Size: pulumi.String("Y1"),
			},
		})
		if err != nil {
			return err
		}
		return nil
	})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Azure = Pulumi.Azure;
return await Deployment.RunAsync(() => 
{
    var example = new Azure.Core.ResourceGroup("example", new()
    {
        Name = "api-rg-pro",
        Location = "West Europe",
    });
    var examplePlan = new Azure.AppService.Plan("example", new()
    {
        Name = "api-appserviceplan-pro",
        Location = example.Location,
        ResourceGroupName = example.Name,
        Kind = "FunctionApp",
        Sku = new Azure.AppService.Inputs.PlanSkuArgs
        {
            Tier = "Dynamic",
            Size = "Y1",
        },
    });
});
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.appservice.Plan;
import com.pulumi.azure.appservice.PlanArgs;
import com.pulumi.azure.appservice.inputs.PlanSkuArgs;
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 example = new ResourceGroup("example", ResourceGroupArgs.builder()
            .name("api-rg-pro")
            .location("West Europe")
            .build());
        var examplePlan = new Plan("examplePlan", PlanArgs.builder()
            .name("api-appserviceplan-pro")
            .location(example.location())
            .resourceGroupName(example.name())
            .kind("FunctionApp")
            .sku(PlanSkuArgs.builder()
                .tier("Dynamic")
                .size("Y1")
                .build())
            .build());
    }
}
resources:
  example:
    type: azure:core:ResourceGroup
    properties:
      name: api-rg-pro
      location: West Europe
  examplePlan:
    type: azure:appservice:Plan
    name: example
    properties:
      name: api-appserviceplan-pro
      location: ${example.location}
      resourceGroupName: ${example.name}
      kind: FunctionApp
      sku:
        tier: Dynamic
        size: Y1
Linux)
import * as pulumi from "@pulumi/pulumi";
import * as azure from "@pulumi/azure";
const example = new azure.core.ResourceGroup("example", {
    name: "api-rg-pro",
    location: "West Europe",
});
const examplePlan = new azure.appservice.Plan("example", {
    name: "api-appserviceplan-pro",
    location: example.location,
    resourceGroupName: example.name,
    kind: "Linux",
    reserved: true,
    sku: {
        tier: "Standard",
        size: "S1",
    },
});
import pulumi
import pulumi_azure as azure
example = azure.core.ResourceGroup("example",
    name="api-rg-pro",
    location="West Europe")
example_plan = azure.appservice.Plan("example",
    name="api-appserviceplan-pro",
    location=example.location,
    resource_group_name=example.name,
    kind="Linux",
    reserved=True,
    sku={
        "tier": "Standard",
        "size": "S1",
    })
package main
import (
	"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/appservice"
	"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/core"
	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
	pulumi.Run(func(ctx *pulumi.Context) error {
		example, err := core.NewResourceGroup(ctx, "example", &core.ResourceGroupArgs{
			Name:     pulumi.String("api-rg-pro"),
			Location: pulumi.String("West Europe"),
		})
		if err != nil {
			return err
		}
		_, err = appservice.NewPlan(ctx, "example", &appservice.PlanArgs{
			Name:              pulumi.String("api-appserviceplan-pro"),
			Location:          example.Location,
			ResourceGroupName: example.Name,
			Kind:              pulumi.Any("Linux"),
			Reserved:          pulumi.Bool(true),
			Sku: &appservice.PlanSkuArgs{
				Tier: pulumi.String("Standard"),
				Size: pulumi.String("S1"),
			},
		})
		if err != nil {
			return err
		}
		return nil
	})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Azure = Pulumi.Azure;
return await Deployment.RunAsync(() => 
{
    var example = new Azure.Core.ResourceGroup("example", new()
    {
        Name = "api-rg-pro",
        Location = "West Europe",
    });
    var examplePlan = new Azure.AppService.Plan("example", new()
    {
        Name = "api-appserviceplan-pro",
        Location = example.Location,
        ResourceGroupName = example.Name,
        Kind = "Linux",
        Reserved = true,
        Sku = new Azure.AppService.Inputs.PlanSkuArgs
        {
            Tier = "Standard",
            Size = "S1",
        },
    });
});
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.appservice.Plan;
import com.pulumi.azure.appservice.PlanArgs;
import com.pulumi.azure.appservice.inputs.PlanSkuArgs;
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 example = new ResourceGroup("example", ResourceGroupArgs.builder()
            .name("api-rg-pro")
            .location("West Europe")
            .build());
        var examplePlan = new Plan("examplePlan", PlanArgs.builder()
            .name("api-appserviceplan-pro")
            .location(example.location())
            .resourceGroupName(example.name())
            .kind("Linux")
            .reserved(true)
            .sku(PlanSkuArgs.builder()
                .tier("Standard")
                .size("S1")
                .build())
            .build());
    }
}
resources:
  example:
    type: azure:core:ResourceGroup
    properties:
      name: api-rg-pro
      location: West Europe
  examplePlan:
    type: azure:appservice:Plan
    name: example
    properties:
      name: api-appserviceplan-pro
      location: ${example.location}
      resourceGroupName: ${example.name}
      kind: Linux
      reserved: true
      sku:
        tier: Standard
        size: S1
Windows Container)
import * as pulumi from "@pulumi/pulumi";
import * as azure from "@pulumi/azure";
const example = new azure.core.ResourceGroup("example", {
    name: "api-rg-pro",
    location: "West Europe",
});
const examplePlan = new azure.appservice.Plan("example", {
    name: "api-appserviceplan-pro",
    location: example.location,
    resourceGroupName: example.name,
    kind: "xenon",
    isXenon: true,
    sku: {
        tier: "PremiumContainer",
        size: "PC2",
    },
});
import pulumi
import pulumi_azure as azure
example = azure.core.ResourceGroup("example",
    name="api-rg-pro",
    location="West Europe")
example_plan = azure.appservice.Plan("example",
    name="api-appserviceplan-pro",
    location=example.location,
    resource_group_name=example.name,
    kind="xenon",
    is_xenon=True,
    sku={
        "tier": "PremiumContainer",
        "size": "PC2",
    })
package main
import (
	"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/appservice"
	"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/core"
	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
	pulumi.Run(func(ctx *pulumi.Context) error {
		example, err := core.NewResourceGroup(ctx, "example", &core.ResourceGroupArgs{
			Name:     pulumi.String("api-rg-pro"),
			Location: pulumi.String("West Europe"),
		})
		if err != nil {
			return err
		}
		_, err = appservice.NewPlan(ctx, "example", &appservice.PlanArgs{
			Name:              pulumi.String("api-appserviceplan-pro"),
			Location:          example.Location,
			ResourceGroupName: example.Name,
			Kind:              pulumi.Any("xenon"),
			IsXenon:           pulumi.Bool(true),
			Sku: &appservice.PlanSkuArgs{
				Tier: pulumi.String("PremiumContainer"),
				Size: pulumi.String("PC2"),
			},
		})
		if err != nil {
			return err
		}
		return nil
	})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Azure = Pulumi.Azure;
return await Deployment.RunAsync(() => 
{
    var example = new Azure.Core.ResourceGroup("example", new()
    {
        Name = "api-rg-pro",
        Location = "West Europe",
    });
    var examplePlan = new Azure.AppService.Plan("example", new()
    {
        Name = "api-appserviceplan-pro",
        Location = example.Location,
        ResourceGroupName = example.Name,
        Kind = "xenon",
        IsXenon = true,
        Sku = new Azure.AppService.Inputs.PlanSkuArgs
        {
            Tier = "PremiumContainer",
            Size = "PC2",
        },
    });
});
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.appservice.Plan;
import com.pulumi.azure.appservice.PlanArgs;
import com.pulumi.azure.appservice.inputs.PlanSkuArgs;
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 example = new ResourceGroup("example", ResourceGroupArgs.builder()
            .name("api-rg-pro")
            .location("West Europe")
            .build());
        var examplePlan = new Plan("examplePlan", PlanArgs.builder()
            .name("api-appserviceplan-pro")
            .location(example.location())
            .resourceGroupName(example.name())
            .kind("xenon")
            .isXenon(true)
            .sku(PlanSkuArgs.builder()
                .tier("PremiumContainer")
                .size("PC2")
                .build())
            .build());
    }
}
resources:
  example:
    type: azure:core:ResourceGroup
    properties:
      name: api-rg-pro
      location: West Europe
  examplePlan:
    type: azure:appservice:Plan
    name: example
    properties:
      name: api-appserviceplan-pro
      location: ${example.location}
      resourceGroupName: ${example.name}
      kind: xenon
      isXenon: true
      sku:
        tier: PremiumContainer
        size: PC2
Create Plan Resource
Resources are created with functions called constructors. To learn more about declaring and configuring resources, see Resources.
Constructor syntax
new Plan(name: string, args: PlanArgs, opts?: CustomResourceOptions);@overload
def Plan(resource_name: str,
         args: PlanArgs,
         opts: Optional[ResourceOptions] = None)
@overload
def Plan(resource_name: str,
         opts: Optional[ResourceOptions] = None,
         resource_group_name: Optional[str] = None,
         sku: Optional[PlanSkuArgs] = None,
         app_service_environment_id: Optional[str] = None,
         is_xenon: Optional[bool] = None,
         kind: Optional[str] = None,
         location: Optional[str] = None,
         maximum_elastic_worker_count: Optional[int] = None,
         name: Optional[str] = None,
         per_site_scaling: Optional[bool] = None,
         reserved: Optional[bool] = None,
         tags: Optional[Mapping[str, str]] = None,
         zone_redundant: Optional[bool] = None)func NewPlan(ctx *Context, name string, args PlanArgs, opts ...ResourceOption) (*Plan, error)public Plan(string name, PlanArgs args, CustomResourceOptions? opts = null)type: azure:appservice:Plan
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 PlanArgs
- 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 PlanArgs
- 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 PlanArgs
- The arguments to resource properties.
- opts ResourceOption
- Bag of options to control resource's behavior.
- name string
- The unique name of the resource.
- args PlanArgs
- The arguments to resource properties.
- opts CustomResourceOptions
- Bag of options to control resource's behavior.
- name String
- The unique name of the resource.
- args PlanArgs
- 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 planResource = new Azure.AppService.Plan("planResource", new()
{
    ResourceGroupName = "string",
    Sku = new Azure.AppService.Inputs.PlanSkuArgs
    {
        Size = "string",
        Tier = "string",
        Capacity = 0,
    },
    AppServiceEnvironmentId = "string",
    IsXenon = false,
    Kind = "string",
    Location = "string",
    MaximumElasticWorkerCount = 0,
    Name = "string",
    PerSiteScaling = false,
    Reserved = false,
    Tags = 
    {
        { "string", "string" },
    },
    ZoneRedundant = false,
});
example, err := appservice.NewPlan(ctx, "planResource", &appservice.PlanArgs{
	ResourceGroupName: pulumi.String("string"),
	Sku: &appservice.PlanSkuArgs{
		Size:     pulumi.String("string"),
		Tier:     pulumi.String("string"),
		Capacity: pulumi.Int(0),
	},
	AppServiceEnvironmentId:   pulumi.String("string"),
	IsXenon:                   pulumi.Bool(false),
	Kind:                      pulumi.Any("string"),
	Location:                  pulumi.String("string"),
	MaximumElasticWorkerCount: pulumi.Int(0),
	Name:                      pulumi.String("string"),
	PerSiteScaling:            pulumi.Bool(false),
	Reserved:                  pulumi.Bool(false),
	Tags: pulumi.StringMap{
		"string": pulumi.String("string"),
	},
	ZoneRedundant: pulumi.Bool(false),
})
var planResource = new Plan("planResource", PlanArgs.builder()
    .resourceGroupName("string")
    .sku(PlanSkuArgs.builder()
        .size("string")
        .tier("string")
        .capacity(0)
        .build())
    .appServiceEnvironmentId("string")
    .isXenon(false)
    .kind("string")
    .location("string")
    .maximumElasticWorkerCount(0)
    .name("string")
    .perSiteScaling(false)
    .reserved(false)
    .tags(Map.of("string", "string"))
    .zoneRedundant(false)
    .build());
plan_resource = azure.appservice.Plan("planResource",
    resource_group_name="string",
    sku={
        "size": "string",
        "tier": "string",
        "capacity": 0,
    },
    app_service_environment_id="string",
    is_xenon=False,
    kind="string",
    location="string",
    maximum_elastic_worker_count=0,
    name="string",
    per_site_scaling=False,
    reserved=False,
    tags={
        "string": "string",
    },
    zone_redundant=False)
const planResource = new azure.appservice.Plan("planResource", {
    resourceGroupName: "string",
    sku: {
        size: "string",
        tier: "string",
        capacity: 0,
    },
    appServiceEnvironmentId: "string",
    isXenon: false,
    kind: "string",
    location: "string",
    maximumElasticWorkerCount: 0,
    name: "string",
    perSiteScaling: false,
    reserved: false,
    tags: {
        string: "string",
    },
    zoneRedundant: false,
});
type: azure:appservice:Plan
properties:
    appServiceEnvironmentId: string
    isXenon: false
    kind: string
    location: string
    maximumElasticWorkerCount: 0
    name: string
    perSiteScaling: false
    reserved: false
    resourceGroupName: string
    sku:
        capacity: 0
        size: string
        tier: string
    tags:
        string: string
    zoneRedundant: false
Plan Resource Properties
To learn more about resource properties and how to use them, see Inputs and Outputs in the Architecture and Concepts docs.
Inputs
In Python, inputs that are objects can be passed either as argument classes or as dictionary literals.
The Plan resource accepts the following input properties:
- ResourceGroup stringName 
- The name of the resource group in which to create the App Service Plan component. Changing this forces a new resource to be created.
- Sku
PlanSku 
- A skublock as documented below.
- AppService stringEnvironment Id 
- The ID of the App Service Environment where the App Service Plan should be located. Changing forces a new resource to be created. - NOTE: Attaching to an App Service Environment requires the App Service Plan use a - PremiumSKU (when using an ASEv1) and the- IsolatedSKU (for an ASEv2).
- IsXenon bool
- Whether to create a xenon App Service Plan.
- Kind string | string
- The kind of the App Service Plan to create. Possible values are - Windows(also available as- App),- Linux,- elastic(for Premium Consumption),- xenonand- FunctionApp(for a Consumption Plan). Defaults to- Windows. Changing this forces a new resource to be created.- NOTE: When creating a - LinuxApp Service Plan, the- reservedfield must be set to- true, and when creating a- Windows/- appApp Service Plan the- reservedfield must be set to- false.
- Location string
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- MaximumElastic intWorker Count 
- The maximum number of total workers allowed for this ElasticScaleEnabled App Service Plan.
- Name string
- Specifies the name of the App Service Plan component. Changing this forces a new resource to be created.
- PerSite boolScaling 
- Can Apps assigned to this App Service Plan be scaled independently? If set to falseapps assigned to this plan will scale to all instances of the plan.
- Reserved bool
- Is this App Service Plan Reserved.
- Dictionary<string, string>
- A mapping of tags to assign to the resource.
- ZoneRedundant bool
- Specifies if the App Service Plan should be Zone Redundant. Changing this forces a new resource to be created. - NOTE: Requires either - PremiumV2or- PremiumV3SKU and that at least 3 instances. For more information, please see the App Service Team Blog.
- ResourceGroup stringName 
- The name of the resource group in which to create the App Service Plan component. Changing this forces a new resource to be created.
- Sku
PlanSku Args 
- A skublock as documented below.
- AppService stringEnvironment Id 
- The ID of the App Service Environment where the App Service Plan should be located. Changing forces a new resource to be created. - NOTE: Attaching to an App Service Environment requires the App Service Plan use a - PremiumSKU (when using an ASEv1) and the- IsolatedSKU (for an ASEv2).
- IsXenon bool
- Whether to create a xenon App Service Plan.
- Kind string | string
- The kind of the App Service Plan to create. Possible values are - Windows(also available as- App),- Linux,- elastic(for Premium Consumption),- xenonand- FunctionApp(for a Consumption Plan). Defaults to- Windows. Changing this forces a new resource to be created.- NOTE: When creating a - LinuxApp Service Plan, the- reservedfield must be set to- true, and when creating a- Windows/- appApp Service Plan the- reservedfield must be set to- false.
- Location string
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- MaximumElastic intWorker Count 
- The maximum number of total workers allowed for this ElasticScaleEnabled App Service Plan.
- Name string
- Specifies the name of the App Service Plan component. Changing this forces a new resource to be created.
- PerSite boolScaling 
- Can Apps assigned to this App Service Plan be scaled independently? If set to falseapps assigned to this plan will scale to all instances of the plan.
- Reserved bool
- Is this App Service Plan Reserved.
- map[string]string
- A mapping of tags to assign to the resource.
- ZoneRedundant bool
- Specifies if the App Service Plan should be Zone Redundant. Changing this forces a new resource to be created. - NOTE: Requires either - PremiumV2or- PremiumV3SKU and that at least 3 instances. For more information, please see the App Service Team Blog.
- resourceGroup StringName 
- The name of the resource group in which to create the App Service Plan component. Changing this forces a new resource to be created.
- sku
PlanSku 
- A skublock as documented below.
- appService StringEnvironment Id 
- The ID of the App Service Environment where the App Service Plan should be located. Changing forces a new resource to be created. - NOTE: Attaching to an App Service Environment requires the App Service Plan use a - PremiumSKU (when using an ASEv1) and the- IsolatedSKU (for an ASEv2).
- isXenon Boolean
- Whether to create a xenon App Service Plan.
- kind String | String
- The kind of the App Service Plan to create. Possible values are - Windows(also available as- App),- Linux,- elastic(for Premium Consumption),- xenonand- FunctionApp(for a Consumption Plan). Defaults to- Windows. Changing this forces a new resource to be created.- NOTE: When creating a - LinuxApp Service Plan, the- reservedfield must be set to- true, and when creating a- Windows/- appApp Service Plan the- reservedfield must be set to- false.
- location String
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- maximumElastic IntegerWorker Count 
- The maximum number of total workers allowed for this ElasticScaleEnabled App Service Plan.
- name String
- Specifies the name of the App Service Plan component. Changing this forces a new resource to be created.
- perSite BooleanScaling 
- Can Apps assigned to this App Service Plan be scaled independently? If set to falseapps assigned to this plan will scale to all instances of the plan.
- reserved Boolean
- Is this App Service Plan Reserved.
- Map<String,String>
- A mapping of tags to assign to the resource.
- zoneRedundant Boolean
- Specifies if the App Service Plan should be Zone Redundant. Changing this forces a new resource to be created. - NOTE: Requires either - PremiumV2or- PremiumV3SKU and that at least 3 instances. For more information, please see the App Service Team Blog.
- resourceGroup stringName 
- The name of the resource group in which to create the App Service Plan component. Changing this forces a new resource to be created.
- sku
PlanSku 
- A skublock as documented below.
- appService stringEnvironment Id 
- The ID of the App Service Environment where the App Service Plan should be located. Changing forces a new resource to be created. - NOTE: Attaching to an App Service Environment requires the App Service Plan use a - PremiumSKU (when using an ASEv1) and the- IsolatedSKU (for an ASEv2).
- isXenon boolean
- Whether to create a xenon App Service Plan.
- kind string | Kind
- The kind of the App Service Plan to create. Possible values are - Windows(also available as- App),- Linux,- elastic(for Premium Consumption),- xenonand- FunctionApp(for a Consumption Plan). Defaults to- Windows. Changing this forces a new resource to be created.- NOTE: When creating a - LinuxApp Service Plan, the- reservedfield must be set to- true, and when creating a- Windows/- appApp Service Plan the- reservedfield must be set to- false.
- location string
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- maximumElastic numberWorker Count 
- The maximum number of total workers allowed for this ElasticScaleEnabled App Service Plan.
- name string
- Specifies the name of the App Service Plan component. Changing this forces a new resource to be created.
- perSite booleanScaling 
- Can Apps assigned to this App Service Plan be scaled independently? If set to falseapps assigned to this plan will scale to all instances of the plan.
- reserved boolean
- Is this App Service Plan Reserved.
- {[key: string]: string}
- A mapping of tags to assign to the resource.
- zoneRedundant boolean
- Specifies if the App Service Plan should be Zone Redundant. Changing this forces a new resource to be created. - NOTE: Requires either - PremiumV2or- PremiumV3SKU and that at least 3 instances. For more information, please see the App Service Team Blog.
- resource_group_ strname 
- The name of the resource group in which to create the App Service Plan component. Changing this forces a new resource to be created.
- sku
PlanSku Args 
- A skublock as documented below.
- app_service_ strenvironment_ id 
- The ID of the App Service Environment where the App Service Plan should be located. Changing forces a new resource to be created. - NOTE: Attaching to an App Service Environment requires the App Service Plan use a - PremiumSKU (when using an ASEv1) and the- IsolatedSKU (for an ASEv2).
- is_xenon bool
- Whether to create a xenon App Service Plan.
- kind str | str
- The kind of the App Service Plan to create. Possible values are - Windows(also available as- App),- Linux,- elastic(for Premium Consumption),- xenonand- FunctionApp(for a Consumption Plan). Defaults to- Windows. Changing this forces a new resource to be created.- NOTE: When creating a - LinuxApp Service Plan, the- reservedfield must be set to- true, and when creating a- Windows/- appApp Service Plan the- reservedfield must be set to- false.
- location str
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- maximum_elastic_ intworker_ count 
- The maximum number of total workers allowed for this ElasticScaleEnabled App Service Plan.
- name str
- Specifies the name of the App Service Plan component. Changing this forces a new resource to be created.
- per_site_ boolscaling 
- Can Apps assigned to this App Service Plan be scaled independently? If set to falseapps assigned to this plan will scale to all instances of the plan.
- reserved bool
- Is this App Service Plan Reserved.
- Mapping[str, str]
- A mapping of tags to assign to the resource.
- zone_redundant bool
- Specifies if the App Service Plan should be Zone Redundant. Changing this forces a new resource to be created. - NOTE: Requires either - PremiumV2or- PremiumV3SKU and that at least 3 instances. For more information, please see the App Service Team Blog.
- resourceGroup StringName 
- The name of the resource group in which to create the App Service Plan component. Changing this forces a new resource to be created.
- sku Property Map
- A skublock as documented below.
- appService StringEnvironment Id 
- The ID of the App Service Environment where the App Service Plan should be located. Changing forces a new resource to be created. - NOTE: Attaching to an App Service Environment requires the App Service Plan use a - PremiumSKU (when using an ASEv1) and the- IsolatedSKU (for an ASEv2).
- isXenon Boolean
- Whether to create a xenon App Service Plan.
- kind String |
- The kind of the App Service Plan to create. Possible values are - Windows(also available as- App),- Linux,- elastic(for Premium Consumption),- xenonand- FunctionApp(for a Consumption Plan). Defaults to- Windows. Changing this forces a new resource to be created.- NOTE: When creating a - LinuxApp Service Plan, the- reservedfield must be set to- true, and when creating a- Windows/- appApp Service Plan the- reservedfield must be set to- false.
- location String
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- maximumElastic NumberWorker Count 
- The maximum number of total workers allowed for this ElasticScaleEnabled App Service Plan.
- name String
- Specifies the name of the App Service Plan component. Changing this forces a new resource to be created.
- perSite BooleanScaling 
- Can Apps assigned to this App Service Plan be scaled independently? If set to falseapps assigned to this plan will scale to all instances of the plan.
- reserved Boolean
- Is this App Service Plan Reserved.
- Map<String>
- A mapping of tags to assign to the resource.
- zoneRedundant Boolean
- Specifies if the App Service Plan should be Zone Redundant. Changing this forces a new resource to be created. - NOTE: Requires either - PremiumV2or- PremiumV3SKU and that at least 3 instances. For more information, please see the App Service Team Blog.
Outputs
All input properties are implicitly available as output properties. Additionally, the Plan resource produces the following output properties:
- Id string
- The provider-assigned unique ID for this managed resource.
- MaximumNumber intOf Workers 
- The maximum number of workers supported with the App Service Plan's sku.
- Id string
- The provider-assigned unique ID for this managed resource.
- MaximumNumber intOf Workers 
- The maximum number of workers supported with the App Service Plan's sku.
- id String
- The provider-assigned unique ID for this managed resource.
- maximumNumber IntegerOf Workers 
- The maximum number of workers supported with the App Service Plan's sku.
- id string
- The provider-assigned unique ID for this managed resource.
- maximumNumber numberOf Workers 
- The maximum number of workers supported with the App Service Plan's sku.
- id str
- The provider-assigned unique ID for this managed resource.
- maximum_number_ intof_ workers 
- The maximum number of workers supported with the App Service Plan's sku.
- id String
- The provider-assigned unique ID for this managed resource.
- maximumNumber NumberOf Workers 
- The maximum number of workers supported with the App Service Plan's sku.
Look up Existing Plan Resource
Get an existing Plan 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?: PlanState, opts?: CustomResourceOptions): Plan@staticmethod
def get(resource_name: str,
        id: str,
        opts: Optional[ResourceOptions] = None,
        app_service_environment_id: Optional[str] = None,
        is_xenon: Optional[bool] = None,
        kind: Optional[str] = None,
        location: Optional[str] = None,
        maximum_elastic_worker_count: Optional[int] = None,
        maximum_number_of_workers: Optional[int] = None,
        name: Optional[str] = None,
        per_site_scaling: Optional[bool] = None,
        reserved: Optional[bool] = None,
        resource_group_name: Optional[str] = None,
        sku: Optional[PlanSkuArgs] = None,
        tags: Optional[Mapping[str, str]] = None,
        zone_redundant: Optional[bool] = None) -> Planfunc GetPlan(ctx *Context, name string, id IDInput, state *PlanState, opts ...ResourceOption) (*Plan, error)public static Plan Get(string name, Input<string> id, PlanState? state, CustomResourceOptions? opts = null)public static Plan get(String name, Output<String> id, PlanState state, CustomResourceOptions options)resources:  _:    type: azure:appservice:Plan    get:      id: ${id}- 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.
- AppService stringEnvironment Id 
- The ID of the App Service Environment where the App Service Plan should be located. Changing forces a new resource to be created. - NOTE: Attaching to an App Service Environment requires the App Service Plan use a - PremiumSKU (when using an ASEv1) and the- IsolatedSKU (for an ASEv2).
- IsXenon bool
- Whether to create a xenon App Service Plan.
- Kind string | string
- The kind of the App Service Plan to create. Possible values are - Windows(also available as- App),- Linux,- elastic(for Premium Consumption),- xenonand- FunctionApp(for a Consumption Plan). Defaults to- Windows. Changing this forces a new resource to be created.- NOTE: When creating a - LinuxApp Service Plan, the- reservedfield must be set to- true, and when creating a- Windows/- appApp Service Plan the- reservedfield must be set to- false.
- Location string
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- MaximumElastic intWorker Count 
- The maximum number of total workers allowed for this ElasticScaleEnabled App Service Plan.
- MaximumNumber intOf Workers 
- The maximum number of workers supported with the App Service Plan's sku.
- Name string
- Specifies the name of the App Service Plan component. Changing this forces a new resource to be created.
- PerSite boolScaling 
- Can Apps assigned to this App Service Plan be scaled independently? If set to falseapps assigned to this plan will scale to all instances of the plan.
- Reserved bool
- Is this App Service Plan Reserved.
- ResourceGroup stringName 
- The name of the resource group in which to create the App Service Plan component. Changing this forces a new resource to be created.
- Sku
PlanSku 
- A skublock as documented below.
- Dictionary<string, string>
- A mapping of tags to assign to the resource.
- ZoneRedundant bool
- Specifies if the App Service Plan should be Zone Redundant. Changing this forces a new resource to be created. - NOTE: Requires either - PremiumV2or- PremiumV3SKU and that at least 3 instances. For more information, please see the App Service Team Blog.
- AppService stringEnvironment Id 
- The ID of the App Service Environment where the App Service Plan should be located. Changing forces a new resource to be created. - NOTE: Attaching to an App Service Environment requires the App Service Plan use a - PremiumSKU (when using an ASEv1) and the- IsolatedSKU (for an ASEv2).
- IsXenon bool
- Whether to create a xenon App Service Plan.
- Kind string | string
- The kind of the App Service Plan to create. Possible values are - Windows(also available as- App),- Linux,- elastic(for Premium Consumption),- xenonand- FunctionApp(for a Consumption Plan). Defaults to- Windows. Changing this forces a new resource to be created.- NOTE: When creating a - LinuxApp Service Plan, the- reservedfield must be set to- true, and when creating a- Windows/- appApp Service Plan the- reservedfield must be set to- false.
- Location string
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- MaximumElastic intWorker Count 
- The maximum number of total workers allowed for this ElasticScaleEnabled App Service Plan.
- MaximumNumber intOf Workers 
- The maximum number of workers supported with the App Service Plan's sku.
- Name string
- Specifies the name of the App Service Plan component. Changing this forces a new resource to be created.
- PerSite boolScaling 
- Can Apps assigned to this App Service Plan be scaled independently? If set to falseapps assigned to this plan will scale to all instances of the plan.
- Reserved bool
- Is this App Service Plan Reserved.
- ResourceGroup stringName 
- The name of the resource group in which to create the App Service Plan component. Changing this forces a new resource to be created.
- Sku
PlanSku Args 
- A skublock as documented below.
- map[string]string
- A mapping of tags to assign to the resource.
- ZoneRedundant bool
- Specifies if the App Service Plan should be Zone Redundant. Changing this forces a new resource to be created. - NOTE: Requires either - PremiumV2or- PremiumV3SKU and that at least 3 instances. For more information, please see the App Service Team Blog.
- appService StringEnvironment Id 
- The ID of the App Service Environment where the App Service Plan should be located. Changing forces a new resource to be created. - NOTE: Attaching to an App Service Environment requires the App Service Plan use a - PremiumSKU (when using an ASEv1) and the- IsolatedSKU (for an ASEv2).
- isXenon Boolean
- Whether to create a xenon App Service Plan.
- kind String | String
- The kind of the App Service Plan to create. Possible values are - Windows(also available as- App),- Linux,- elastic(for Premium Consumption),- xenonand- FunctionApp(for a Consumption Plan). Defaults to- Windows. Changing this forces a new resource to be created.- NOTE: When creating a - LinuxApp Service Plan, the- reservedfield must be set to- true, and when creating a- Windows/- appApp Service Plan the- reservedfield must be set to- false.
- location String
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- maximumElastic IntegerWorker Count 
- The maximum number of total workers allowed for this ElasticScaleEnabled App Service Plan.
- maximumNumber IntegerOf Workers 
- The maximum number of workers supported with the App Service Plan's sku.
- name String
- Specifies the name of the App Service Plan component. Changing this forces a new resource to be created.
- perSite BooleanScaling 
- Can Apps assigned to this App Service Plan be scaled independently? If set to falseapps assigned to this plan will scale to all instances of the plan.
- reserved Boolean
- Is this App Service Plan Reserved.
- resourceGroup StringName 
- The name of the resource group in which to create the App Service Plan component. Changing this forces a new resource to be created.
- sku
PlanSku 
- A skublock as documented below.
- Map<String,String>
- A mapping of tags to assign to the resource.
- zoneRedundant Boolean
- Specifies if the App Service Plan should be Zone Redundant. Changing this forces a new resource to be created. - NOTE: Requires either - PremiumV2or- PremiumV3SKU and that at least 3 instances. For more information, please see the App Service Team Blog.
- appService stringEnvironment Id 
- The ID of the App Service Environment where the App Service Plan should be located. Changing forces a new resource to be created. - NOTE: Attaching to an App Service Environment requires the App Service Plan use a - PremiumSKU (when using an ASEv1) and the- IsolatedSKU (for an ASEv2).
- isXenon boolean
- Whether to create a xenon App Service Plan.
- kind string | Kind
- The kind of the App Service Plan to create. Possible values are - Windows(also available as- App),- Linux,- elastic(for Premium Consumption),- xenonand- FunctionApp(for a Consumption Plan). Defaults to- Windows. Changing this forces a new resource to be created.- NOTE: When creating a - LinuxApp Service Plan, the- reservedfield must be set to- true, and when creating a- Windows/- appApp Service Plan the- reservedfield must be set to- false.
- location string
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- maximumElastic numberWorker Count 
- The maximum number of total workers allowed for this ElasticScaleEnabled App Service Plan.
- maximumNumber numberOf Workers 
- The maximum number of workers supported with the App Service Plan's sku.
- name string
- Specifies the name of the App Service Plan component. Changing this forces a new resource to be created.
- perSite booleanScaling 
- Can Apps assigned to this App Service Plan be scaled independently? If set to falseapps assigned to this plan will scale to all instances of the plan.
- reserved boolean
- Is this App Service Plan Reserved.
- resourceGroup stringName 
- The name of the resource group in which to create the App Service Plan component. Changing this forces a new resource to be created.
- sku
PlanSku 
- A skublock as documented below.
- {[key: string]: string}
- A mapping of tags to assign to the resource.
- zoneRedundant boolean
- Specifies if the App Service Plan should be Zone Redundant. Changing this forces a new resource to be created. - NOTE: Requires either - PremiumV2or- PremiumV3SKU and that at least 3 instances. For more information, please see the App Service Team Blog.
- app_service_ strenvironment_ id 
- The ID of the App Service Environment where the App Service Plan should be located. Changing forces a new resource to be created. - NOTE: Attaching to an App Service Environment requires the App Service Plan use a - PremiumSKU (when using an ASEv1) and the- IsolatedSKU (for an ASEv2).
- is_xenon bool
- Whether to create a xenon App Service Plan.
- kind str | str
- The kind of the App Service Plan to create. Possible values are - Windows(also available as- App),- Linux,- elastic(for Premium Consumption),- xenonand- FunctionApp(for a Consumption Plan). Defaults to- Windows. Changing this forces a new resource to be created.- NOTE: When creating a - LinuxApp Service Plan, the- reservedfield must be set to- true, and when creating a- Windows/- appApp Service Plan the- reservedfield must be set to- false.
- location str
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- maximum_elastic_ intworker_ count 
- The maximum number of total workers allowed for this ElasticScaleEnabled App Service Plan.
- maximum_number_ intof_ workers 
- The maximum number of workers supported with the App Service Plan's sku.
- name str
- Specifies the name of the App Service Plan component. Changing this forces a new resource to be created.
- per_site_ boolscaling 
- Can Apps assigned to this App Service Plan be scaled independently? If set to falseapps assigned to this plan will scale to all instances of the plan.
- reserved bool
- Is this App Service Plan Reserved.
- resource_group_ strname 
- The name of the resource group in which to create the App Service Plan component. Changing this forces a new resource to be created.
- sku
PlanSku Args 
- A skublock as documented below.
- Mapping[str, str]
- A mapping of tags to assign to the resource.
- zone_redundant bool
- Specifies if the App Service Plan should be Zone Redundant. Changing this forces a new resource to be created. - NOTE: Requires either - PremiumV2or- PremiumV3SKU and that at least 3 instances. For more information, please see the App Service Team Blog.
- appService StringEnvironment Id 
- The ID of the App Service Environment where the App Service Plan should be located. Changing forces a new resource to be created. - NOTE: Attaching to an App Service Environment requires the App Service Plan use a - PremiumSKU (when using an ASEv1) and the- IsolatedSKU (for an ASEv2).
- isXenon Boolean
- Whether to create a xenon App Service Plan.
- kind String |
- The kind of the App Service Plan to create. Possible values are - Windows(also available as- App),- Linux,- elastic(for Premium Consumption),- xenonand- FunctionApp(for a Consumption Plan). Defaults to- Windows. Changing this forces a new resource to be created.- NOTE: When creating a - LinuxApp Service Plan, the- reservedfield must be set to- true, and when creating a- Windows/- appApp Service Plan the- reservedfield must be set to- false.
- location String
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- maximumElastic NumberWorker Count 
- The maximum number of total workers allowed for this ElasticScaleEnabled App Service Plan.
- maximumNumber NumberOf Workers 
- The maximum number of workers supported with the App Service Plan's sku.
- name String
- Specifies the name of the App Service Plan component. Changing this forces a new resource to be created.
- perSite BooleanScaling 
- Can Apps assigned to this App Service Plan be scaled independently? If set to falseapps assigned to this plan will scale to all instances of the plan.
- reserved Boolean
- Is this App Service Plan Reserved.
- resourceGroup StringName 
- The name of the resource group in which to create the App Service Plan component. Changing this forces a new resource to be created.
- sku Property Map
- A skublock as documented below.
- Map<String>
- A mapping of tags to assign to the resource.
- zoneRedundant Boolean
- Specifies if the App Service Plan should be Zone Redundant. Changing this forces a new resource to be created. - NOTE: Requires either - PremiumV2or- PremiumV3SKU and that at least 3 instances. For more information, please see the App Service Team Blog.
Supporting Types
PlanSku, PlanSkuArgs    
Import
App Service Plan instances can be imported using the resource id, e.g.
$ pulumi import azure:appservice/plan:Plan instance1 /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/mygroup1/providers/Microsoft.Web/serverFarms/instance1
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 azurermTerraform Provider.