Deploy and manage an LKE cluster with the Linode API
An LKE cluster can be deployed in one of several ways:
- Via Cloud Manager
- With the Linode API (as presented in this guide)
- With the Linode CLI
These Linode-provided interfaces can be used to create, delete, and update the structural elements of your cluster, including:
- The number of nodes that make up a cluster's node pools.
- The region where your node pools are deployed.
- The hardware resources for each node in your node pools.
- The Kubernetes version deployed to your cluster's Master node and worker nodes.
The Kubernetes API and kubectl are the primary ways you interact with your LKE cluster once it's been created. These tools can be used to configure, deploy, inspect, and secure your Kubernetes workloads, deploy applications, create services, configure storage and networking, and define controllers.
The Linode API and the Kubernetes API are two separate interfaces, and both are mentioned in this article. The Linode API lets you manipulate your Linode infrastructure, while the Kubernetes API lets you manage the software objects running in your cluster.
In this guide
This guide covers how to use the Linode API to:
- Create an LKE cluster
- Connect kubectl to your LKE cluster
- Inspect your LKE cluster
- Modify an existing LKE cluster
- Delete an LKE cluster
Before you begin
- 
Familiarize yourself with the Linode Kubernetes Engine service. This information helps you understand the benefits and limitations of LKE. 
- 
Create an API Token. You need this to access the LKE service. 
- 
Install kubectl on your computer. You use kubectl to interact with your cluster once it's deployed. 
- 
If you are new to Kubernetes, refer to our A Beginner's Guide to Kubernetes series to learn about general Kubernetes concepts. This guide assumes a general understanding of core Kubernetes concepts. 
Create an LKE cluster
| Required Parameters | Description | 
|---|---|
| region | The data center region where your cluster is deployed. Currently, us-centralis the only available region for LKE clusters. | 
| label | A human readable name to identify your cluster. This must be unique. If no label is provided, one is assigned automatically. Labels must start with an alpha [a-z][A-Z] character, must only consist of alphanumeric characters and dashes, and must not contain two dashes in a row. | 
| node_pools | The collections of Linodes that serve as the worker nodes in your LKE cluster. | 
| k8s_version | The desired version of Kubernetes for this cluster. | 
The available plan types for LKE worker nodes are Shared, Dedicated CPU, and High Memory plans.
- 
To create an LKE Cluster, send a POSTrequest to the/lke/clustersendpoint. The example below displays all possible request body parameters. Note thattagsis an optional parameter.curl -H "Content-Type: application/json" \ -H "Authorization: Bearer $TOKEN" \ -X POST -d '{ "label": "cluster12345", "region": "us-central", "k8s_version": "1.16", "tags": ["ecomm", "blogs"], "node_pools": [ { "type": "g6-standard-2", "count": 2}, { "type": "g6-standard-4", "count": 3} ] }' https://api.linode.com/v4/lke/clustersYou receive a response similar to: {"k8s_version": "1.16", "updated": "2019-08-02T17:17:49", "region": "us-central", "tags": ["ecomm", "blogs"], "label": "cluster12345", "id": 456, "created": "2019-22-02T17:17:49"}%
- 
Make note of your cluster's ID, as you need it to continue to interact with your cluster in the next sections. In the example above, the cluster's ID is "id": 456. You can also access your cluster's ID by listing all LKE Clusters on your account.Each Linode account has a limit to the number of resources they can deploy. This includes services, like Linodes, NodeBalancers, Block Storage, etc. If you run into issues deploying the number of nodes you designate for a given cluster's node pool, you may have run into a limit on the number of resources allowed on your account. Contact Linode Support if you believe this may be the case. 
Connect to your LKE cluster
Now that your LKE cluster is created, you can access and manage your cluster using kubectl on your computer. This gives you the ability to interact with the Kubernetes API, and to create and manage Kubernetes objects in your cluster.
To communicate with your LKE cluster, kubectl requires a copy of your cluster's kubeconfig. In this section, you access the contents of your kubeconfig using the Linode API and then set up kubectl to communicate with your LKE cluster.
- 
Access your LKE cluster's kubeconfig file by sending a GETrequest to the/lke/clusters/{clusterId}/kubeconfigendpoint. Ensure you replace12345with your cluster's ID that you recorded in the previous section:curl -H "Authorization: Bearer $TOKEN" \ https://api.linode.com/v4/lke/clusters/12345/kubeconfigThe API returns a base64 encoded string (a useful format for automated pipelines) representing your kubeconfig. Your output resembles the following: {"kubeconfig": "YXBpVmVyc2lvbjogdjEKY2x1c3RlcnM6Ci0gY2x1c3RlcjoKICAgIGNlcnRpZmljYXRlLWF1dGhvcml0eS1kYXRhOiBMUzB0TFMxQ1JVZEpUaUJEUlZKVVNVWkpRMEZVUlMwdExTMHRDazFKU1VONVJFTkRRV0pEWjBGM1NVSkJaMGxDUVVSQlRrSm5hM0ZvYTJsSE9YY3dRa0ZSYzBaQlJFRldUVkpOZDBWUldVUldVVkZFUlhkd2NtUlhTbXdLWTIwMWJHUkhWbnBOUWpSWVJGUkZOVTFFWjNkTmFrVXpUVlJqTVUxV2IxaEVWRWsx ... 0TFMwdExRbz0K"}%
- 
Copy the kubeconfigfield's value from the response body, since you need it in the next step.Make sure you only copy the long string inside the quotes following "kubeconfig":in your output. Do not copy the curly braces or anything outside of them. You receive an error if you use the full output in later steps.
- 
Save the base64 kubeconfig to an environment variable: KUBE_VAR='YXBpVmVyc2lvbjogdjEK ... 0TFMwdExRbz0K'
- 
Navigate to your computer's ~/.kubedirectory. This is where kubectl looks for kubeconfig files, by default.cd ~/.kube
- 
Create a directory called configswithin~/.kube. You can use this directory to store your kubeconfig files.mkdir configs cd configs
- 
Decode the contents of $KUBE_VARand save it to a new YAML file:echo $KUBE_VAR | base64 -D > cluster12345-config.yamlThe YAML file that you decode to ( cluster12345-config.yamlhere) can have any name of your choosing.
- 
Add the kubeconfig file to your $KUBECONFIGenvironment variable.export KUBECONFIG=cluster12345-config.yaml
- 
Verify that your cluster is selected as kubectl's current context: kubectl config get-contexts
- 
View the contents of the configuration: kubectl config viewYou can also access a decoded version of your kubeconfig file in Cloud Manager. 
- 
View all nodes in your LKE cluster using kubectl: kubectl get nodesYour output resembles the following example, but varies depending on your own cluster's configurations. NAME STATUS ROLES AGE VERSION lke166-193-5d44703cd092 Ready none 2d22h v1.14.0 lke166-194-5d44703cd780 Ready none 2d22h v1.14.0 lke166-195-5d44703cd691 Ready none 2d22h v1.14.0 lke166-196-5d44703cd432 Ready none 2d22h v1.14.0 lke166-197-5d44703cd211 Ready none 2d22h v1.14.0Now that you are connected to your LKE cluster, you can begin using kubectl to deploy applications, inspect and manage cluster resources, and view logs. 
Persist the kubeconfig context
If you create a new terminal window, it does not have access to the context that you specified using the previous instructions. This context information can be made persistent between new terminals by setting the KUBECONFIG environment variable in your shell's configuration file.
If you are using Windows, review the official Kubernetes documentation for how to persist your context.
These instructions persist the context for users of the Bash terminal. They are similar for users of other terminals:
- 
Open up your Bash profile (e.g. ~/.bash_profile) in the text editor of your choice and add your configuration file to the$KUBECONFIGPATH variable.If an export KUBECONFIGline is already present in the file, append to the end of this line as follows; if it is not present, add this line to the end of your file:export KUBECONFIG=$KUBECONFIG:$HOME/.kube/config:$HOME/.kube/configs/cluster12345-config.yamlAlter the $HOME/.kube/configs/cluster12345-config.yamlpath in the above line with the name of the file you decoded to in the previous section.
- 
Close your terminal window and open a new window to receive the changes to the $KUBECONFIGvariable.
- 
Use the config get-contextscommand forkubectlto view the available cluster contexts:kubectl config get-contextsYou should see output similar to the following: CURRENT NAME CLUSTER AUTHINFO NAMESPACE * kubernetes-admin@kubernetes kubernetes kubernetes-admin
- 
If your context is not already selected, (denoted by an asterisk in the currentcolumn), switch to this context using theconfig use-contextcommand. Supply the full name of the cluster (including the authorized user and the cluster):kubectl config use-context kubernetes-admin@kubernetesYou should see output like the following: Switched to context "kubernetes-admin@kubernetes".
- 
You are now ready to interact with your cluster using kubectl. You can test the ability to interact with the cluster by retrieving a list of Pods in thekube-systemnamespace:kubectl get pods -n kube-system
Inspect your LKE cluster
Once you have created an LKE Cluster, you can access information about its structural configuration using the Linode API.
List LKE clusters
To view a list of all your LKE clusters, send a GET request to the /lke/clusters endpoint.
curl -H "Authorization: Bearer $TOKEN" https://api.linode.com/v4/lke/clusters
The returned response body displays the number of clusters deployed to your account and general details about your LKE clusters:
{"results": 2, "data": [{"updated": "2019-08-02T17:17:49", "region": "us-central", "id": 456, "k8s_version": "1.16", "label": "cluster-12345", "created": "2019-08-02T17:17:49", "tags": ["ecomm", "blogs"]}, {"updated": "2019-08-05T17:00:04", "region": "us-central", "id": 789, "k8s_version": "1.16", "label": "cluster-56789", "created": "2019-08-05T17:00:04", "tags": ["ecomm", "marketing"]}], "pages": 1, "page": 1}%
View an LKE cluster
You can use the Linode API to access details about an individual LKE cluster. You need your cluster's ID to access information about this resource. If you don't know your cluster's ID, see the List LKE Clusters section.
| Required Parameters | Description | 
|---|---|
| clusterId | ID of the LKE cluster to lookup. | 
To view your LKE cluster, send a GET request to the /lke/clusters/{clusterId} endpoint. In this example, ensure you replace 12345 with your cluster's ID:
curl -H "Authorization: Bearer $TOKEN" https://api.linode.com/v4/lke/clusters/12345
Your output resembles the following:
{"created": "2019-08-02T17:17:49", "updated": "2019-08-02T17:17:49", "k8s_version": "1.16", "tags": ["ecomm", "blogs"], "label": "cluster-12345", "id": 456, "region": "us-central"}%
List a cluster's node pools
A node pool consists of one or more Linodes (worker nodes). Each node in the pool has the same plan type. Your LKE cluster can have several node pools. Each pool is assigned its own plan type and number of nodes. To view a list of an LKE cluster's node pools, you need your cluster's ID. If you don't know your cluster's ID, see the List LKE Clusters section.
| Required Parameters | Description | 
|---|---|
| clusterId | ID of the LKE cluster to lookup. | 
To list your cluster's node pools, send a GET request to the /lke/clusters/{clusterId}/pools endpoint. In this example, replace 12345 with your cluster's ID:
curl -H "Authorization: Bearer $TOKEN" https://api.linode.com/v4/lke/clusters/12345/pools
The response body includes information on each node pool's pool ID, Linode type, and node count; and each node's individual ID and status.
{"pages": 1, "page": 1, "data": [{"count": 2, "id": 193, "type": "g6-standard-2", "linodes": [{"id": "13841932", "status": "ready "}, {"id": "13841933", "status": "ready"}]}, {"count": 3, "id": 194, "type": "g6-standard-4", "linodes": [{"id": "13841934", "status": "ready"}, {"id": "13841935", "status": "ready"}, {"id": "13841932", "status": "ready"}]}], "results": 2}%
View a node pool
You can use the Linode API to access details about a specific node pool in an LKE cluster. You need your cluster’s ID and node pool ID to access information about this resource. To retrieve your cluster’s ID, see the List LKE Clusters section. To find a node pool's ID, see the List a Cluster's Node Pools section.
| Required Parameters | Description | 
|---|---|
| clusterId | ID of the LKE cluster to lookup. | 
| poolId | ID of the LKE node pool to lookup. | 
To view a specific node pool, send a GET request to the /lke/clusters/{clusterId}/pools/{poolId} endpoint. In this example, replace 12345 with your cluster's ID and 456 with the node pool's ID:
curl -H "Authorization: Bearer $TOKEN" \
    https://api.linode.com/v4/lke/clusters/12345/pools/456
The response body provides information about the number of nodes in the node pool, the node pool's ID, and type. You also retrieve information about each individual node in the node pool, including the Linode's ID and status.
{"count": 2, "id": 193, "type": "g6-standard-2", "linodes": [{"id": "13841932", "status": "ready"}, {"id": "13841933", "status": "ready"}]}%
If desired, you can use your node pool's Linodes ID(s) to get more details about each node in the pool. Send a
GETrequest to the/linode/instances/{linodeId}endpoint. In this example, ensure you replace13841932with your Linode's ID.curl -H "Authorization: Bearer $TOKEN" \ https://api.linode.com/v4/linode/instances/13841932Although you have access to your cluster's nodes, it is recommended that you only interact with your nodes via the Linode's LKE interfaces (like the LKE endpoints in Linode's API, or the Kubernetes section in Cloud Manager), or via the Kubernetes API and kubectl.
Modify your LKE cluster
Once an LKE cluster is created, you can modify the cluster's label, node pools, and tags. In this section you learn how to modify each of these parts of your cluster.
Update your LKE cluster label
| Required Parameters | Description | 
|---|---|
| clusterId | ID of the LKE cluster to lookup. | 
To update your LKE cluster's label, send a PUT request to the /lke/clusters/{clusterId} endpoint. In this example, ensure you replace 12345 with your cluster's ID:
curl -H "Content-Type: application/json" \
        -H "Authorization: Bearer $TOKEN" \
        -X PUT -d '{
        "label": "updated-cluster-name"
        }' https://api.linode.com/v4/lke/clusters/12345
The response body displays the updated cluster label:
{"created": "2019-08-02T17:17:49", "updated": "2019-08-05T19:11:19", "k8s_version": "1.16", "tags": ["ecomm", "blogs"], "label": "updated-cluster-name", "id": 456, "region": "us-central"}%
Add a node pool to your LKE cluster
A node pool consists of one or more Linodes (worker nodes). Each node in the pool has the same plan type and is identical to each other. Your LKE cluster can have several node pools, each pool with its own plan type and number of nodes.
You need your cluster's ID in order to add a node pool to it. If you don’t know your cluster’s ID, see the List LKE Clusters section.
| Required Parameters | Description | 
|---|---|
| clusterId | ID of the LKE cluster to lookup. | 
| type | The Linode plan type to use for all the nodes in the pool. Linode plans designate the type of hardware resources applied to your Linode. | 
| count | The number of nodes to include in the node pool. Each node has the same plan type. | 
To add a node pool to an existing LKE cluster, send a POST request to the /lke/clusters/{clusterId}/pools endpoint. The request body must include the type and count parameters. In the URL of this example, ensure you replace 12345 with your own cluster's ID:
curl -H "Content-Type: application/json" \
        -H "Authorization: Bearer $TOKEN" \
        -X POST -d '{
        "type": "g6-standard-1",
        "count": 5
        }' https://api.linode.com/v4/lke/clusters/12345/pools
The response body resembles the following:
{"count": 5, "id": 196, "type": "g6-standard-1", "linodes": [{"id": "13841945", "status": "ready"}, {"id": "13841946", "status": "ready"}, {"id": "13841947", "status": "ready"}, {"id": "13841948", "status": "ready"}, {"id": "13841949", "status": "ready"}]}%
Each Linode account has a limit to the number of resources they can deploy. This includes services, like Linodes, NodeBalancers, Block Storage, etc. If you run into issues deploying the number of nodes you designate for a given cluster's node pool, you may have run into a limit on the number of resources allowed on your account. Contact Linode Support if you believe this may be the case.
Add labels and taints to your LKE node pools
When creating or updating an LKE node pool, you can optionally add custom labels and taints to all nodes using the labels and taints parameters. Defining labels and taints on a per-pool basis through the Linode API has several benefits compared to managing them manually with kubectl, including:
- Custom labels and taints automatically apply to new nodes when a pool is recycled or scaled up (either manually or through autoscaling).
- LKE ensures that nodes have the desired taints in place before they become ready for pod scheduling. This prevents newly created nodes from attracting workloads that don't have the intended tolerations.
The following cURL command provides an example of using the Linode API to create a new node pool with a custom taint and label. If you are copying this command to run on your own LKE cluster, replace {{< placeholder "12345" >}} with the ID of your LKE cluster.
curl -H "Content-Type: application/json" \
        -H "Authorization: Bearer $TOKEN" \
        -X POST -d '{
        "type": "g6-standard-1",
        "count": 3,
        "taints": [
            {
                "key": "myapp.io/app",
                "value": "test",
                "effect": "NoSchedule"
            }
        ],
        "labels": {
            "myapp.io/app": "test"
        }
        }' https://api.linode.com/v4/lke/clusters/{{< placeholder "12345" >}}/pools
In the above command, labels are defined in the labels field as key-value pairs within a single object. Taints are defined as an array of objects in the taints field.
- 
Labels: The labelsfield expects an object with one or more key-value pairs. These key-value pairs should adhere to the specifications and restrictions outlined in the Kubernetes Labels and Selectors documentation."labels": { "myapp.io/app": "test" }- 
Key: A label's key must begin with a letter or number, and may contain letters, numbers, hyphens, dots, and underscores. Optionally, the key can begin with a valid DNS subdomain prefix. - If the key does not begin with a DNS subdomain prefix, the maximum key length is 63 characters. Example: my-app.
- If the key begins with a DNS subdomain prefix, it must separate the prefix and the rest of the label with a forward slash (/). In this case, the maximum total length of the key is 128 characters, with up to 62 characters after the forward slash. The prefix must adhere to RFC 1123 DNS subdomain restrictions. Example:example.com/my-app.
 
- If the key does not begin with a DNS subdomain prefix, the maximum key length is 63 characters. Example: 
- 
Value: Must begin with a letter or number, and may contain letters, numbers, hyphens, dots, and underscores, up to 63 characters in length. 
 
- 
- 
Taints: The taintsfield expects an array of one or more objects, adhering to the guidelines outlined in the Kubernetes Taints and Tolerations documentation. A taint consists of akey,value, andeffect:"taints": [ { "key": "myapp.io/app", "value": "test", "effect": "NoSchedule" } ]- Key: The keyvalue must begin with a letter or number, and may contain letters, numbers, hyphens, dots, and underscores, up to 253 characters. Optionally, thekeyvalue can begin with a DNS subdomain prefix and a single slash (/), likeexample.com/my-app. In this case the maximum allowed length of the domain prefix is 253 characters.
- Value: The valuekey is optional. If given, it must begin with a letter or number, and may contain letters, numbers, hyphens, dots, and underscores, up to 63 characters.
- Effect: The effectvalue must be NoSchedule, PreferNoSchedule, or NoExecute.
 
- Key: The 
Taint and label values cannot contain
kubernetes.ioorlinode.comdomains as these are reserved for LKE's own usage.
You can also add, edit, or remove labels and taints on existing node pools using the Linode API. The example cURL command below demonstrates how to remove taints and update the labels on an existing node pool. If you are copying this command to run on your own LKE cluster, replace {{< placeholder "12345" >}} with the ID of your LKE cluster and {{< placeholder "196" >}} with the ID of your node pool.
curl -H "Content-Type: application/json" \
    -H "Authorization: Bearer $TOKEN" \
    -X PUT -d '{
        "type": "g6-standard-1",
        "count": 3,
        "taints": [],
        "labels": {
            "myapp.io/app": "prod",
            "example": "foo",
        }
    }' https://api.linode.com/v4/lke/clusters/{{< placeholder "12345" >}}/pools/{{< placeholder "196" >}}
The above command results in the following changes to the node pool, assuming the labels and taints were originally entered as shown in the first create command.
- Removes the "myapp.io/app" taint by specifying an empty array in the taintsfield.
- Changes the label "myapp.io/app" to have a value of "prod" instead of "test".
- Adds the new label "example=foo".
When updating or adding labels and taints to an existing node pool, it is not necessary to recycle it. This is because the values are updated live on the running nodes.
Resize your LKE node pool
You can resize an LKE cluster's node pool to add or decrease its number of nodes. You need your cluster's ID and the node pool's ID in order to resize it. If you don’t know your cluster’s ID, see the List LKE Clusters section. If you don’t know your node pool's ID, see the List a Cluster’s Node Pools section.
Shrinking a node pool results in deletion of Linodes. Any local storage on deleted Linodes (such as
hostPathandemptyDirvolumes, or "local" PersistentVolumes) is erased.
You cannot modify an existing node pool's plan type. If you would like your LKE cluster to use a different node pool plan type, you can add a new node pool to your cluster with the same number of nodes to replace the current node pool. You can then delete the node pool that is no longer needed.
| Required Parameters | Description | 
|---|---|
| clusterId | ID of the LKE cluster to lookup. | 
| poolId | ID of the LKE node pool to lookup. | 
| count | The number of Linodes in the node pool. | 
To update your node pool's node count, send a PUT request to the /lke/clusters/{clusterId}/pools/{poolId} endpoint. In the URL of this example, replace 12345 with your cluster's ID and 196 with your node pool's ID:
curl -H "Content-Type: application/json" \
    -H "Authorization: Bearer $TOKEN" \
    -X PUT -d '{
        "type": "g6-standard-4",
        "count": 6
    }' https://api.linode.com/v4/lke/clusters/12345/pools/196
Each Linode account has a limit to the number of resources they can deploy. This includes services, like Linodes, NodeBalancers, Block Storage, etc. If you run into issues deploying the number of nodes you designate for a given cluster's node pool, you may have run into a limit on the number of resources allowed on your account. Contact Linode Support if you believe this may be the case.
Recycle all nodes within a cluster
You can recycle all nodes within an LKE cluster to upgrade the nodes to the most recent patch of the cluster's Kubernetes version and to otherwise replace the Linodes that comprise the cluster. Nodes are recycled on a rolling basis, meaning that only one node is down at a time throughout the recycling process. You need your cluster's ID in order to recycle it's nodes. If you don’t know your cluster’s ID, see the List LKE Clusters section.
Recycling your cluster involves deleting each of the Linodes in the node pool and replacing them with new Linodes. Any local storage on deleted Linodes (such as
hostPathandemptyDirvolumes, or "local" PersistentVolumes) is erased.
| Required Parameters | Description | 
|---|---|
| clusterId | ID of the LKE cluster to lookup. | 
To recycle all nodes within a cluster, send a POST request to the /lke/clusters/{clusterId}/pools/{poolId}/recycle endpoint. In the URL of this example, replace 12345 with your cluster's ID:
curl -H "Content-Type: application/json" \
    -H "Authorization: Bearer $TOKEN" \
    -X POST \
    https://api.linode.com/v4/lke/clusters/12345/recycle
Recycle your LKE node pool
You can recycle an LKE cluster's node pool to upgrade its nodes to the most recent patch of the cluster's Kubernetes version. Nodes are recycled on a rolling basis, meaning that only one node is down at a time throughout the recycling process. You need your cluster's ID and the node pool's ID in order to recycle it. If you don’t know your cluster’s ID, see the List LKE Clusters section. If you don’t know your node pool's ID, see the List a Cluster’s Node Pools section.
Recycling your node pool involves deleting each of the Linodes in the node pool and replacing them with new Linodes. Any local storage on deleted Linodes (such as
hostPathandemptyDirvolumes, or "local" PersistentVolumes) is erased.
| Required Parameters | Description | 
|---|---|
| clusterId | ID of the LKE cluster to lookup. | 
| poolId | ID of the LKE node pool to lookup. | 
To recycle your node pool, send a POST request to the /lke/clusters/{clusterId}/pools/{poolId}/recycle endpoint. In the URL of this example, replace 12345 with your cluster's ID and 196 with your node pool's ID:
curl -H "Content-Type: application/json" \
    -H "Authorization: Bearer $TOKEN" \
    -X POST \
    https://api.linode.com/v4/lke/clusters/12345/pools/196/recycle
Recycle a single node within a node pool
You can recycle an individual node within a LKE Cluster's Node Pool. You need your cluster's ID and the node ID in order to recycle it. If you don’t know your cluster’s ID, see the List LKE Clusters section. If you don’t know your node ID, see the List a Cluster’s Node Pools section.
Recycling a Node involves deleting that Linode and replacing it with a new Linode. Any local storage on the deleted Linode (such as
hostPathandemptyDirvolumes, or "local" PersistentVolumes) is erased.
| Required Parameters | Description | 
|---|---|
| clusterId | ID of the LKE cluster to lookup. | 
| nodeId | ID of the LKE node to lookup. | 
To recycle your node, send a POST request to the /lke/clusters/{clusterId}/nodes/{nodeId}/recycle endpoint. In the URL of this example, replace 12345 with your cluster's ID and 12345-6aa78910bc with your node ID:
curl -H "Authorization: Bearer $TOKEN" \
    https://api.linode.com/v4/lke/clusters/12345/nodes/12345-6aa78910bc
Upgrade your LKE cluster to the next minor version
| Required Parameters | Description | 
|---|---|
| clusterId | ID of the LKE cluster to lookup. | 
| k8s_version | The next minor version of Kubernetes | 
To upgrade your LKE cluster's version, send a PUT request to the /lke/clusters/{clusterId} endpoint. In this example, ensure you replace 12345 with your cluster's ID, and 1.17 with whichever Kubernetes version is the next currently available:
curl -H "Content-Type: application/json" \
        -H "Authorization: Bearer $TOKEN" \
        -X PUT -d '{
        "k8s_version": "1.17"
        }' https://api.linode.com/v4/lke/clusters/12345
The response body displays the cluster version that will be applied following a recycle:
{"created": "2019-08-02T17:17:49", "updated": "2019-08-05T19:11:19", "k8s_version": "1.17", "tags": ["ecomm", "blogs"], "label": "updated-cluster-name", "id": 456, "region": "us-central"}%
Nodes within the LKE cluster must be recycled before the cluster version will be successfully upgraded.
Add new tags to your LKE cluster
Like many Linode resources, you can add tags to your LKE Cluster for organizational purposes. This section shows you how to add new tags to an existing LKE Cluster.
View all of your account's tags
To view all of the tags existing on your account, issue the following request against the API:
curl -H "Authorization: Bearer $TOKEN" \ https://api.linode.com/v4/tagsYour response resembles the example:
{"data": [{"label": "blogs"}, {"label": "ecomm"}, {"label": "prod"}, {"label": "monitoring"}], "page": 1, "pages": 1, "results": 4}%
- 
View the tags currently assigned to your cluster: curl -H "Authorization: Bearer $TOKEN" \ https://api.linode.com/v4/lke/clusters/12345The response body contains an array of your cluster's tags. In the example response, the cluster's tags are blog, andecomm.{"id": 12345, "status": "ready", "created": "2020-04-13T20:17:22", "updated": "2020-04-13T20:17:22", "label": "cluster-12345", "region": "us-central", "k8s_version": "1.17", "tags": ["blog", "ecomm"]}%
- 
To add new tags to your cluster's existing tags, your request must include a tagsarray with all previous and new tags. The example request adds the new tagsprodandmonitoringto the cluster.curl -H "Content-Type: application/json" \ -H "Authorization: Bearer $TOKEN" \ -X PUT -d '{ "tags" : ["ecomm", "blog", "prod", "monitoring"] }' \ https://api.linode.com/v4/lke/clusters/12345The response displays all of your cluster's tags. In the example response, the cluster's tags are now blog,ecomm,prod, andmonitoring.{"id": 12345, "status": "ready", "created": "2020-04-13T20:17:22", "updated": "2020-04-13T20:17:22", "label": "cluster-12345", "region": "us-central", "k8s_version": "1.17", "tags": ["blog", "ecomm", "monitoring", "prod"]}%
Delete tags from your LKE cluster
This section shows you how to delete tags from your LKE Cluster.
- 
View the tags currently assigned to your cluster: curl -H "Authorization: Bearer $TOKEN" \ https://api.linode.com/v4/lke/clusters/12345The response body contains an array of your cluster's tags. In the example response, the cluster's tags are blog,ecomm,prod, andmonitoring.{"id": 12345, "status": "ready", "created": "2020-04-13T20:17:22", "updated": "2020-04-13T20:17:22", "label": "cluster-12345", "region": "us-central", "k8s_version": "1.17", "tags": [["blog", "ecomm", "monitoring", "prod"]}%
- 
To delete a tag from your cluster, issue a request with only the tags you would like to keep assigned to your cluster. In the example request, the tags monitoringandprodare excluded from thetagsarray and so are deleted from your cluster.curl -H "Content-Type: application/json" \ -H "Authorization: Bearer $TOKEN" \ -X PUT -d '{ "tags" : ["ecomm", "blog"] }' \ https://api.linode.com/v4/lke/clusters/12345The response displays all of your cluster's current tags. In the example response, the cluster's tags are now blog, andecomm.{"id": 12345, "status": "ready", "created": "2020-04-13T20:17:22", "updated": "2020-04-13T20:17:22", "label": "cluster-12345", "region": "us-central", "k8s_version": "1.17", "tags": ["blog", "ecomm"]}%
Delete a node pool from an LKE cluster
When you delete a node pool you also delete the Linodes (nodes) and routes to them. The Pods running on those nodes are evicted and rescheduled. If you have assigned Pods to the deleted Nodes, the Pods might remain in an unschedulable condition if no other node in the cluster satisfies the node selector.
| Required Parameters | Description | 
|---|---|
| clusterId | ID of the LKE cluster to lookup. | 
| poolId | ID of the LKE node pool to lookup. | 
To delete a node pool from a LKE cluster, send a DELETE request to the /lke/clusters/{clusterId}/pools/{poolId} end point. In the URL of this example, replace 12345 with your cluster's ID and 196 with your cluster's node pool ID:
This step is permanent and results in the loss of data.
curl -H "Authorization: Bearer $TOKEN" \
    -X DELETE \
    https://api.linode.com/v4/lke/clusters/12345/pools/196
Delete an LKE cluster
Deleting an LKE cluster deletes the Master node, all worker nodes, and all NodeBalancers created by the cluster. However, it does not delete any volumes created by the LKE cluster.
To delete an LKE Cluster, send a DELETE request to the /lke/clusters/{clusterId} endpoint. In the URL of this example, replace 12345 with your cluster's ID:
This step is permanent and results in the loss of data.
curl -H "Authorization: Bearer $TOKEN" \
    -X DELETE \
    https://api.linode.com/v4/lke/clusters/12345
Where to go from here?
Now that you have created an LKE cluster, you can start deploying workloads to it. Review these guides for further help:
Updated 9 months ago
