-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathk8s_storage.tf
72 lines (70 loc) · 3.27 KB
/
k8s_storage.tf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
resource "proxmox_vm_qemu" "k8s_storage" {
depends_on = [proxmox_vm_qemu.k8s_master_main]
count = var.k8s_storage_nodes
name = "${var.vm_name_prefix}-storage-${count.index + 1}"
target_node = var.proxmox_node_name
clone = var.vm_template_name
agent = 1
cloudinit_cdrom_storage = var.vm_cloudinit_storage
os_type = "cloud-init"
cores = var.storage_node_cpu
sockets = var.storage_node_socket
cpu = "host"
memory = var.storage_node_memory
scsihw = "virtio-scsi-pci"
ipconfig0 = "ip=${var.ip_address_start}.${var.storage_node_ip_start + count.index}/${var.ip_address_cidr},gw=${var.ip_address_gateway}"
ciuser = var.vm_user
cipassword = var.vm_password
sshkeys = var.ssh_public_key
qemu_os = "l26"
desc = "${var.vm_name_prefix}-storage-${count.index + 1}, generated by Terraform Alx v${var.module_version}"
disks {
scsi {
scsi0 {
disk {
size = var.storage_node_disk
storage = var.vm_cloudinit_storage
}
}
}
}
network {
model = "virtio"
bridge = var.proxmox_bridge_name
}
provisioner "remote-exec" {
connection {
type = "ssh"
user = var.vm_user
private_key = var.ssh_private_key
host = self.ssh_host
}
inline = [
"until sudo apt-get update; do echo 'apt-get update failed, retrying...'; sleep 5; done",
"until sudo apt-get install -y nfs-kernel-server; do echo 'nfs-kernel-server installation failed, retrying...'; sleep 5; done",
"sudo mkdir -p /mnt/nfs-share",
"sudo chown nobody:nogroup /mnt/nfs-share",
"sudo chmod 777 /mnt/nfs-share",
"echo '/mnt/nfs-share ${var.ip_address_start}.0/24(rw,sync,no_subtree_check,no_root_squash)' | sudo tee -a /etc/exports",
"sudo systemctl restart nfs-kernel-server",
"sudo systemctl enable nfs-kernel-server",
]
}
provisioner "remote-exec" {
connection {
type = "ssh"
user = var.vm_user
private_key = var.ssh_private_key
host = "${var.ip_address_start}.${var.master_node_ip_start}"
}
inline = [
// create a namespace for all the storage classes if it doesn't exist
"kubectl create ns storage-classes",
"if [ ! -f /usr/local/bin/helm ]; then curl -fsSL -o get_helm.sh https://raw.githubusercontent.com/helm/helm/master/scripts/get-helm-3; chmod 700 get_helm.sh; ./get_helm.sh; fi",
"helm repo add nfs-subdir-external-provisioner https://kubernetes-sigs.github.io/nfs-subdir-external-provisioner",
"helm repo update",
"helm install nfs-subdir-external-provisioner-storage-${count.index + 1} nfs-subdir-external-provisioner/nfs-subdir-external-provisioner --set nfs.server=${self.ssh_host} --set nfs.path=/mnt/nfs-share --set storageClass.name=nfs-client-storage-${count.index + 1} --set storageClass.archiveOnDelete=false --set storageClass.onDelete=delete --namespace storage-classes",
]
}
// TODO: On destroy, remove the storageClass and the provisioner from the cluster
}