Linode Provider
Installation
The linode provider is available as a package in all Pulumi languages:
- JavaScript/TypeScript:
@pulumi/linode
- Python:
pulumi-linode
- Go:
github.com/pulumi/pulumi-linode/sdk/v4/go/linode
- .NET:
Pulumi.Linode
- Java:
com.pulumi/linode
Overview
The Linode provider exposes resources and data sources to interact with Linode services. The provider needs to be configured with the proper credentials before it can be used.
Use the navigation to the left to read about the available data sources.
Example Usage
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: nodejs
import * as pulumi from "@pulumi/pulumi";
import * as linode from "@pulumi/linode";
// Create a Linode
const foobar = new linode.Instance("foobar", {});
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: python
import pulumi
import pulumi_linode as linode
# Create a Linode
foobar = linode.Instance("foobar")
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: dotnet
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Linode = Pulumi.Linode;
return await Deployment.RunAsync(() =>
{
// Create a Linode
var foobar = new Linode.Instance("foobar");
});
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: go
package main
import (
"github.com/pulumi/pulumi-linode/sdk/v4/go/linode"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
// Create a Linode
_, err := linode.NewInstance(ctx, "foobar", nil)
if err != nil {
return err
}
return nil
})
}
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: yaml
resources:
# Create a Linode
foobar:
type: linode:Instance
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: java
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.linode.Instance;
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) {
// Create a Linode
var foobar = new Instance("foobar");
}
}
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: nodejs
import * as pulumi from "@pulumi/pulumi";
import * as linode from "@pulumi/linode";
// Create a Linode
const foobar = new linode.Instance("foobar", {});
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: python
import pulumi
import pulumi_linode as linode
# Create a Linode
foobar = linode.Instance("foobar")
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: dotnet
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Linode = Pulumi.Linode;
return await Deployment.RunAsync(() =>
{
// Create a Linode
var foobar = new Linode.Instance("foobar");
});
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: go
package main
import (
"github.com/pulumi/pulumi-linode/sdk/v4/go/linode"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
// Create a Linode
_, err := linode.NewInstance(ctx, "foobar", nil)
if err != nil {
return err
}
return nil
})
}
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: yaml
resources:
# Create a Linode
foobar:
type: linode:Instance
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: java
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.linode.Instance;
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) {
// Create a Linode
var foobar = new Instance("foobar");
}
}
Configuration Reference
The following keys can be used to configure the provider.
Basic Configuration
This section outlines commonly used provider configuration options.
configPath
- (Optional) The path to the Linode config file to use. (default~/.config/linode
)configProfile
- (Optional) The Linode config profile to use. (defaultdefault
)token
- (Optional) This is your Linode APIv4 Token.The Linode Token can also be specified using the
LINODE_TOKEN
shell environment variable. (e.g.export LINODE_TOKEN=mytoken
)Specifying a token through the
token
field or through theLINODE_TOKEN
shell environment variable will override the token loaded through a config.Configs are not required if a
token
is defined.url
- (Optional) The HTTP(S) API address of the Linode API to use.The Linode API URL can also be specified using the
LINODE_URL
environment variable.Overrides the Linode Config
apiUrl
field.apiVersion
(Optional) The version of the Linode API to use. (defaultv4
)The Linode API version can also be specified using the
LINODE_API_VERSION
environment variable.objAccessKey
- (Optional) The access key to be used in linode.ObjectStorageBucket and linode.ObjectStorageObject.The Object Access Key can also be specified using the
LINODE_OBJ_ACCESS_KEY
shell environment variable.objSecretKey
- (Optional) The secret key to be used in linode.ObjectStorageBucket and linode.ObjectStorageObject.The Object Secret Key can also be specified using the
LINODE_OBJ_SECRET_KEY
shell environment variable.objUseTempKeys
- (Optional) If true, temporary object keys will be created implicitly at apply-time for the linode.ObjectStorageBucket and linode.ObjectStorageObject resource to use.objBucketForceDelete
- (Optional) If true, all objects and versions will purged from a linode.ObjectStorageBucket before it is destroyed.skipInstanceReadyPoll
- (Optional) Skip waiting for a linode.Instance resource to be running.skipInstanceDeletePoll
- (Optional) Skip waiting for a linode.Instance resource to finish deleting.skipImplicitReboots
- (Optional) If true, Linode Instances will not be rebooted on config and interface changes. (defaultfalse
)
Advanced Configuration
This section outlines less frequently used provider configuration options.
uaPrefix
- (Optional) An HTTP User-Agent Prefix to prepend in API requests.The User-Agent Prefix can also be specified using the
LINODE_UA_PREFIX
environment variable.minRetryDelayMs
- (Optional) Minimum delay in milliseconds before retrying a request. (default100
)maxRetryDelayMs
- (Optional) Maximum delay in milliseconds before retrying a request. (default2000
)eventPollMs
- (Optional) The rate in milliseconds to poll for Linode events. (default4000
)The event polling rate can also be configured using the
LINODE_EVENT_POLL_MS
environment variable.lkeEventPollMs
- (Optional) The rate in milliseconds to poll for LKE events. (default3000
)lkeNodeReadyPollMs
- (Optional) The rate in milliseconds to poll for an LKE node to be ready. (default3000
)disableInternalCache
- (Optional) If true, the internal caching system that backs certain Linode API requests will be disabled. (defaultfalse
)
Early Access
Some resources are made available before the feature reaches general availability. These resources are subject to change, and may not be available to all customers in all regions. Early access features can be accessed by configuring the provider to use a different version of the API.
Configuring the Target API Version
The apiVersion
can be set on the provider block like so:
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: nodejs
config:
linode:apiVersion:
value: v4beta
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: python
config:
linode:apiVersion:
value: v4beta
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: dotnet
config:
linode:apiVersion:
value: v4beta
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: go
config:
linode:apiVersion:
value: v4beta
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: yaml
config:
linode:apiVersion:
value: v4beta
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: java
config:
linode:apiVersion:
value: v4beta
Additionally, the version can be set with the LINODE_API_VERSION
environment variable.
Rate Limiting
The Linode API may apply rate limiting when you update the state for a large inventory:
Error: Error getting Linode DomainRecord ID 123456: [002] unexpected end of JSON input
Error: Error finding the specified Linode DomainRecord: [002] unexpected end of JSON input
If this affects you, run Pulumi with –parallelism=1
Using Configuration Files
Configuration files can be used to specify Linode client configuration options across various Linode integrations.
For example:
~/.config/linode
[default]
token = mylinodetoken
Pulumi.yaml
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: nodejs
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: python
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: dotnet
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: go
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: yaml
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: java
Specifying the token
provider options or defining LINODE_TOKEN
in the environment will override any tokens loaded from a configuration file.
Profiles can also be defined for multitenant use-cases. Every profile will inherit fields from the default
profile.
For example:
~/.config/linode
[default]
token = alinodetoken
[foo]
token = anotherlinodetoken
[bar]
token = yetanotherlinodetoken
Pulumi.yaml
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: nodejs
config:
linode:configProfile:
value: bar
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: python
config:
linode:configProfile:
value: bar
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: dotnet
config:
linode:configProfile:
value: bar
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: go
config:
linode:configProfile:
value: bar
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: yaml
config:
linode:configProfile:
value: bar
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: java
config:
linode:configProfile:
value: bar
Configuration Profiles also expose additional client configuration fields such as apiUrl
and apiVersion
.
For example:
~/.config/linode
[default]
token = mylinodetoken
[stable]
api_version = v4
[beta]
api_version = v4beta
[alpha]
api_version = v4beta
api_url = https://my.alpha.endpoint.com
Pulumi.yaml
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: nodejs
config:
linode:configProfile:
value: beta
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: python
config:
linode:configProfile:
value: beta
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: dotnet
config:
linode:configProfile:
value: beta
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: go
config:
linode:configProfile:
value: beta
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: yaml
config:
linode:configProfile:
value: beta
# Pulumi.yaml provider configuration file
name: configuration-example
runtime: java
config:
linode:configProfile:
value: beta