RouteTable

class RouteTable : KotlinCustomResource

Manages a Route Table

NOTE on Route Tables and Routes: There is both a standalone route resource, and allows for Routes to be defined in-line within the route_table resource. At this time you cannot use a Route Table with in-line Routes in conjunction with any Route resources. Doing so will cause a conflict of Route configurations and will overwrite Routes.

Example Usage

import * as pulumi from "@pulumi/pulumi";
import * as azure from "@pulumi/azure";
const example = new azure.core.ResourceGroup("example", {
name: "example-resources",
location: "West Europe",
});
const exampleRouteTable = new azure.network.RouteTable("example", {
name: "example-route-table",
location: example.location,
resourceGroupName: example.name,
disableBgpRoutePropagation: false,
routes: [{
name: "route1",
addressPrefix: "10.1.0.0/16",
nextHopType: "VnetLocal",
}],
tags: {
environment: "Production",
},
});
import pulumi
import pulumi_azure as azure
example = azure.core.ResourceGroup("example",
name="example-resources",
location="West Europe")
example_route_table = azure.network.RouteTable("example",
name="example-route-table",
location=example.location,
resource_group_name=example.name,
disable_bgp_route_propagation=False,
routes=[{
"name": "route1",
"address_prefix": "10.1.0.0/16",
"next_hop_type": "VnetLocal",
}],
tags={
"environment": "Production",
})
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 = "example-resources",
Location = "West Europe",
});
var exampleRouteTable = new Azure.Network.RouteTable("example", new()
{
Name = "example-route-table",
Location = example.Location,
ResourceGroupName = example.Name,
DisableBgpRoutePropagation = false,
Routes = new[]
{
new Azure.Network.Inputs.RouteTableRouteArgs
{
Name = "route1",
AddressPrefix = "10.1.0.0/16",
NextHopType = "VnetLocal",
},
},
Tags =
{
{ "environment", "Production" },
},
});
});
package main
import (
"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/core"
"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/network"
"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("example-resources"),
Location: pulumi.String("West Europe"),
})
if err != nil {
return err
}
_, err = network.NewRouteTable(ctx, "example", &network.RouteTableArgs{
Name: pulumi.String("example-route-table"),
Location: example.Location,
ResourceGroupName: example.Name,
DisableBgpRoutePropagation: pulumi.Bool(false),
Routes: network.RouteTableRouteArray{
&network.RouteTableRouteArgs{
Name: pulumi.String("route1"),
AddressPrefix: pulumi.String("10.1.0.0/16"),
NextHopType: pulumi.String("VnetLocal"),
},
},
Tags: pulumi.StringMap{
"environment": pulumi.String("Production"),
},
})
if err != nil {
return err
}
return nil
})
}
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.RouteTable;
import com.pulumi.azure.network.RouteTableArgs;
import com.pulumi.azure.network.inputs.RouteTableRouteArgs;
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("example-resources")
.location("West Europe")
.build());
var exampleRouteTable = new RouteTable("exampleRouteTable", RouteTableArgs.builder()
.name("example-route-table")
.location(example.location())
.resourceGroupName(example.name())
.disableBgpRoutePropagation(false)
.routes(RouteTableRouteArgs.builder()
.name("route1")
.addressPrefix("10.1.0.0/16")
.nextHopType("VnetLocal")
.build())
.tags(Map.of("environment", "Production"))
.build());
}
}
resources:
example:
type: azure:core:ResourceGroup
properties:
name: example-resources
location: West Europe
exampleRouteTable:
type: azure:network:RouteTable
name: example
properties:
name: example-route-table
location: ${example.location}
resourceGroupName: ${example.name}
disableBgpRoutePropagation: false
routes:
- name: route1
addressPrefix: 10.1.0.0/16
nextHopType: VnetLocal
tags:
environment: Production

Import

Route Tables can be imported using the resource id, e.g.

$ pulumi import azure:network/routeTable:RouteTable example /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/mygroup1/providers/Microsoft.Network/routeTables/mytable1

Properties

Link copied to clipboard
Link copied to clipboard

Boolean flag which controls propagation of routes learned by BGP on that route table. True means disable.

Link copied to clipboard
val id: Output<String>
Link copied to clipboard
val location: Output<String>

Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.

Link copied to clipboard
val name: Output<String>

The name of the route.

Link copied to clipboard
val pulumiChildResources: Set<KotlinResource>
Link copied to clipboard
Link copied to clipboard
Link copied to clipboard

The name of the resource group in which to create the route table. Changing this forces a new resource to be created.

Link copied to clipboard

A list of objects representing routes. Each object accepts the arguments documented below.

Link copied to clipboard
val subnets: Output<List<String>>

The collection of Subnets associated with this route table.

Link copied to clipboard
val tags: Output<Map<String, String>>?

A mapping of tags to assign to the resource.

Link copied to clipboard
val urn: Output<String>