selectel_mks_cluster_v1
This instruction is a copy of the Selectel Terraform provider's documentation in the Terraform Registry.
Creates and manages a Managed Kubernetes cluster using public API v1. For more information about Managed Kubernetes, see the official Selectel documentation.
Example usage
High availability cluster
resource "selectel_mks_cluster_v1" "ha_cluster" {
name = "cluster-1"
project_id = selectel_vpc_project_v2.project_1.id
region = "ru-7"
kube_version = data.selectel_mks_kube_versions_v1.versions.latest_version
}
Basic cluster
resource "selectel_mks_cluster_v1" "basic_cluster" {
name = "cluster-1"
project_id = selectel_vpc_project_v2.project_1.id
region = "ru-7"
kube_version = data.selectel_mks_kube_versions_v1.versions.latest_version
zonal = true
enable_patch_version_auto_upgrade = false
}
Argument Reference
-
name
— (Required) Cluster name. Changing this creates a new cluster. The cluster name is included into the names of the cluster entities: node groups, nodes, load balancers, networks, and volumes. -
project_id
— (Required) Unique identifier of the associated project. Changing this creates a new cluster. Retrieved from the selectel_vpc_project_v2 resource. Learn more about Projects. -
region
— (Required) Pool where the cluster is located, for example,ru-7
. Changing this creates a new cluster. Learn more about available pools in the Availability matrix. -
kube_version
— (Required) Kubernetes version of the cluster. Changing this upgrades the cluster version. You can retrieve information about the Kubernetes versions with the selectel_mks_kube_versions_v1 data source.To upgrade a patch version, the desired version should match the latest available patch version for the current minor release.
To upgrade a minor version, the desired version should match the next available minor release with the latest patch version.
-
zonal
— (Optional) Specifies a cluster type. Changing this creates a new cluster.Boolean flag:
-
false
(default) — for a high availability cluster with three master nodes located on different hosts in one pool segment. -
true
— for a basic cluster with one master node. Setenable_patch_version_auto_upgrade
tofalse
.
Learn more about Cluster types.
-
-
enable_autorepair
— (Optional) Enables or disables node auto-repairing (worker nodes are automatically restarted). Auto-repairing is not available if you have one worker node. After auto-repairing, all data on the boot volumes are deleted. Boolean flag, the default value istrue
. Learn more about Nodes auto-repairing. -
enable_patch_version_auto_upgrade
— (Optional) Enables or disables auto-upgrading of the cluster to the latest available Kubernetes patch version during the maintenance window. Boolean flag, the default value istrue
. Must be set to false for basic clusters (ifzonal
istrue
). Learn more about Patch versions auto-upgrading. -
network_id
— (Optional) Unique identifier of the associated OpenStack network. Changing this creates a new cluster. Learn more about the openstack_networking_network_v2 resource in the official OpenStack documentation. -
subnet_id
— (Optional) Unique identifier of the associated OpenStack subnet. Changing this creates a new cluster. Learn more about the openstack_networking_subnet_v2 resource in the official OpenStack documentation. -
maintenance_window_start
— (Optional) Time in UTC when maintenance in the cluster starts. The format ishh:mm:ss
. Learn more about the Maintenance window. -
feature_gates
— (Optional) Enables or disables feature gates for the cluster. You can retrieve the list of available feature gates with the selectel_mks_feature_gates_v1 data source. Learn more about Feature gates. -
admission_controllers
— (Optional) Enables or disables admission controllers for the cluster. You can retrieve the list of available admission controllers with the selectel_mks_admission_controllers_v1 data source. Learn more about Admission controllers. -
private_kube_api
— (Optional) Specifies if Kube API is available from the Internet. Changing this creates a new cluster.Boolean flag:
-
false
(default) — Kube API is available from the Internet; -
true
— Kube API is available only from the cluster network.
-
-
enable_audit_logs
— (Optional) Enables or disables collection of audit logs. Learn how to configure export of audit logs to a logging system.Boolean flag:
-
false
(default) — Audit logs are not collected and are not available for export; -
true
— Audit logs are collected and available for export.
-
Attributes Reference
-
maintenance_window_end
— Time in UTC when maintenance in the cluster ends. The format ishh:mm:ss
. Learn more about the Maintenance window. -
kube_api_ip
— IP address of the Kube API. -
status
— Cluster status.
Import
You can import a cluster:
export OS_DOMAIN_NAME=<account_id>
export OS_USERNAME=<username>
export OS_PASSWORD=<password>
export INFRA_PROJECT_ID=<selectel_project_id>
export INFRA_REGION=<selectel_pool>
terraform import selectel_mks_cluster_v1.cluster_name <cluster_id>
where:
-
<account_id>
— Selectel account ID. The account ID is in the top right corner of the Control panel. Learn more about Registration. -
<username>
— Name of the service user. To get the name, in the Control panel, go to Identity & Access Management ⟶ User management ⟶ the Service users tab ⟶ copy the name of the required user. Learn more about Service users. -
<password>
— Password of the service user. -
<selectel_project_id>
— Unique identifier of the associated project. To get the ID, in the Control panel, go to Cloud Platform ⟶ project name ⟶ copy the ID of the required project. Learn more about Projects. -
<selectel_pool>
— Pool where the cluster is located, for example,ru-7
. To get information about the pool, in the Control panel, go to Cloud Platform ⟶ Kubernetes. The pool is in the Pool Column. -
<cluster_id>
— Unique identifier of the cluster, for example,b311ce58-2658-46b5-b733-7a0f418703f2
. To get the cluster ID, in the Control panel, go to Cloud Platform ⟶ Kubernetes ⟶ the cluster page ⟶ copy the ID at the top of the page under the cluster name, near the region and pool.