khuedoan-homelab/infra/cluster.tf

76 lines
1.6 KiB
Terraform
Raw Normal View History

provider "rke" {
debug = true
}
locals {
hosts = yamldecode(file("../metal/hosts.yml"))
user = local.hosts.metal.vars.ansible_user
ssh_key_path = local.hosts.metal.vars.ansible_ssh_private_key_file
}
resource "rke_cluster" "cluster" {
dynamic "nodes" {
for_each = [
local.hosts.metal.hosts.metal0.ansible_host,
local.hosts.metal.hosts.metal1.ansible_host,
local.hosts.metal.hosts.metal2.ansible_host
]
content {
address = nodes.value
user = local.user
role = [
"controlplane",
"etcd",
"worker"
]
ssh_key_path = local.ssh_key_path
}
}
dynamic "nodes" {
for_each = [
local.hosts.metal.hosts.metal3.ansible_host
]
content {
address = nodes.value
user = local.user
role = [
"worker"
]
ssh_key_path = local.ssh_key_path
}
}
ingress {
provider = "none"
}
# For CoreOS
network {
plugin = "canal"
options = {
canal_flex_volume_plugin_dir = "/opt/kubernetes/kubelet-plugins/volume/exec/nodeagent~uds"
flannel_backend_type = "vxlan"
canal_flannel_backend_port = "8472"
canal_flannel_backend_type = "vxlan"
canal_flannel_backend_vni = "1"
}
}
services {
kube_controller {
extra_args = {
flex-volume-plugin-dir = "/opt/kubernetes/kubelet-plugins/volume/exec/"
}
}
}
}
resource "local_file" "kube_config_yaml" {
filename = "${path.root}/kube_config.yaml"
sensitive_content = rke_cluster.cluster.kube_config_yaml
file_permission = "0600"
}