2020-11-04 22:46:38 +07:00
|
|
|
provider "rke" {
|
2020-11-15 12:31:58 +07:00
|
|
|
debug = true
|
|
|
|
}
|
|
|
|
|
2020-11-16 01:21:30 +07:00
|
|
|
provider "kubernetes" {
|
|
|
|
config_path = "${path.root}/kube_config.yaml"
|
|
|
|
}
|
|
|
|
|
2020-11-15 12:31:58 +07:00
|
|
|
provider "helm" {
|
|
|
|
kubernetes {
|
|
|
|
config_path = "${path.root}/kube_config.yaml"
|
2020-11-04 22:46:38 +07:00
|
|
|
}
|
2020-11-15 12:31:58 +07:00
|
|
|
}
|
2020-11-04 22:46:38 +07:00
|
|
|
|
|
|
|
resource rke_cluster "cluster" {
|
|
|
|
dynamic "nodes" {
|
|
|
|
for_each = [
|
2020-11-15 00:01:57 +07:00
|
|
|
"192.168.1.110",
|
|
|
|
"192.168.1.111",
|
|
|
|
"192.168.1.112"
|
2020-11-04 22:46:38 +07:00
|
|
|
]
|
|
|
|
content {
|
|
|
|
address = nodes.value
|
|
|
|
user = "root"
|
2020-11-15 12:31:58 +07:00
|
|
|
role = [
|
2020-11-05 01:09:18 +07:00
|
|
|
"controlplane",
|
|
|
|
"etcd",
|
|
|
|
"worker"
|
|
|
|
]
|
|
|
|
ssh_key = file("~/.ssh/id_rsa")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
dynamic "nodes" {
|
|
|
|
for_each = [
|
2020-11-15 00:01:57 +07:00
|
|
|
"192.168.1.113"
|
2020-11-05 01:09:18 +07:00
|
|
|
]
|
|
|
|
content {
|
|
|
|
address = nodes.value
|
|
|
|
user = "root"
|
2020-11-15 12:31:58 +07:00
|
|
|
role = [
|
2020-11-05 01:09:18 +07:00
|
|
|
"worker"
|
2020-11-04 22:46:38 +07:00
|
|
|
]
|
|
|
|
ssh_key = file("~/.ssh/id_rsa")
|
|
|
|
}
|
|
|
|
}
|
2020-11-16 01:21:30 +07:00
|
|
|
|
|
|
|
ingress {
|
|
|
|
provider = "none"
|
|
|
|
}
|
2020-11-04 22:46:38 +07:00
|
|
|
}
|
|
|
|
|
2020-11-05 01:09:18 +07:00
|
|
|
resource "local_file" "kube_config_yaml" {
|
|
|
|
filename = "${path.root}/kube_config.yaml"
|
2020-11-04 22:46:38 +07:00
|
|
|
content = rke_cluster.cluster.kube_config_yaml
|
2020-10-28 23:30:16 +07:00
|
|
|
}
|
2020-11-15 12:31:58 +07:00
|
|
|
|
|
|
|
resource "helm_release" "metallb" {
|
|
|
|
name = "metallb"
|
|
|
|
repository = "https://charts.bitnami.com/bitnami"
|
|
|
|
chart = "metallb"
|
|
|
|
version = "1.0.1"
|
|
|
|
|
|
|
|
namespace = "metallb-system"
|
|
|
|
create_namespace = true
|
|
|
|
|
|
|
|
set {
|
2020-11-15 12:48:00 +07:00
|
|
|
name = "configInline"
|
2020-11-15 12:47:30 +07:00
|
|
|
value = <<EOT
|
|
|
|
address-pools:
|
|
|
|
- name: default
|
|
|
|
protocol: layer2
|
|
|
|
addresses:
|
|
|
|
- 192.168.1.150-192.168.1.180
|
|
|
|
EOT
|
2020-11-15 12:31:58 +07:00
|
|
|
}
|
|
|
|
}
|
2020-11-15 23:47:40 +07:00
|
|
|
|
2020-11-16 01:38:29 +07:00
|
|
|
resource "helm_release" "nginx" {
|
|
|
|
name = "ingress-nginx"
|
|
|
|
repository = "https://kubernetes.github.io/ingress-nginx"
|
|
|
|
chart = "ingress-nginx"
|
|
|
|
version = "3.10.1"
|
|
|
|
|
|
|
|
namespace = "ingress-nginx"
|
|
|
|
create_namespace = true
|
|
|
|
}
|
|
|
|
|
2020-11-21 19:49:17 +07:00
|
|
|
resource "helm_release" "cert_manager" {
|
|
|
|
name = "cert-manager"
|
|
|
|
repository = "https://charts.jetstack.io"
|
|
|
|
chart = "cert-manager"
|
|
|
|
version = "1.0.4"
|
|
|
|
|
|
|
|
namespace = "cert-manager"
|
|
|
|
create_namespace = true
|
2020-11-23 23:21:55 +07:00
|
|
|
|
|
|
|
set {
|
|
|
|
name = "installCRDs"
|
|
|
|
value = "true"
|
|
|
|
}
|
2020-11-21 19:49:17 +07:00
|
|
|
}
|
|
|
|
|
2020-11-15 23:47:40 +07:00
|
|
|
resource "helm_release" "prometheus" {
|
|
|
|
name = "kube-prometheus-stack"
|
|
|
|
repository = "https://prometheus-community.github.io/helm-charts"
|
|
|
|
chart = "kube-prometheus-stack"
|
|
|
|
version = "11.1.2"
|
|
|
|
|
|
|
|
namespace = "monitoring-system"
|
|
|
|
create_namespace = true
|
|
|
|
}
|
2020-11-16 02:00:53 +07:00
|
|
|
|
2020-11-21 16:13:17 +07:00
|
|
|
resource "helm_release" "longhorn" {
|
|
|
|
name = "longhorn"
|
|
|
|
repository = "https://charts.longhorn.io"
|
|
|
|
chart = "longhorn"
|
|
|
|
version = "1.0.2"
|
|
|
|
|
|
|
|
namespace = "longhorn-system"
|
|
|
|
create_namespace = true
|
|
|
|
}
|
|
|
|
|
2020-11-21 01:42:35 +07:00
|
|
|
resource "helm_release" "vault" {
|
|
|
|
name = "vault"
|
|
|
|
repository = "https://helm.releases.hashicorp.com"
|
|
|
|
chart = "vault"
|
|
|
|
version = "0.8.0"
|
|
|
|
|
|
|
|
namespace = "vault"
|
|
|
|
create_namespace = true
|
|
|
|
}
|