Setup resource and data sources and refactor controller setup

This commit is contained in:
Magnus Andersson 2024-05-23 10:47:29 +02:00
parent 45d7f9b334
commit be6e9b21ae
Signed by: mandersson
GPG key ID: 19CB2C58E1F19B16
6 changed files with 73 additions and 21 deletions

5
IaC/images.tf Normal file
View file

@ -0,0 +1,5 @@
# Default os version
data "openstack_images_image_v2" "debian12image" {
name = "debian-12" # Name of image to be used
most_recent = true
}

3
IaC/network.tf Normal file
View file

@ -0,0 +1,3 @@
data "openstack_networking_network_v2" "public" {
name = "public" # Name of network to use.
}

View file

@ -1,26 +1,59 @@
#
# Controller node resources
#
resource "openstack_networking_port_v2" "kubeport" {
name = "${var.controller_name}${count.index+1}-${replace(var.dns_suffix,".","-")}-port"
# We create as many ports as there are instances created
count = var.controller_instance_count
network_id = data.openstack_networking_network_v2.public.id
# A list of security group ID
security_group_ids = [
data.openstack_networking_secgroup_v2.sshfromjumphosts.id,
data.openstack_networking_secgroup_v2.allegress.id,
resource.openstack_networking_secgroup_v2.microk8s.id
]
admin_state_up = "true"
}
resource "openstack_blockstorage_volume_v3" "kubecvolumeboot" {
count = var.controller_instance_count # size of cluster
name = "${var.controller_name}${count.index+1}-${replace(var.dns_suffix,".","-")}-vol"
description = "OS volume for kubernetes control node ${count.index + 1}"
size = 100
image_id = data.openstack_images_image_v2.debian12image.id
enable_online_resize = true # Allow us to resize volume while attached.
}
resource "openstack_compute_instance_v2" "controller-nodes" { resource "openstack_compute_instance_v2" "controller-nodes" {
count = var.controller_instance_count count = var.controller_instance_count
name = "${var.controller_name}-${count.index}.${var.dns_suffix}" name = "${var.controller_name}${count.index+1}.${var.dns_suffix}"
flavor_name = "${var.controller_instance_type}" flavor_name = "${var.controller_instance_type}"
key_pair = "${var.keyname}" key_pair = "${var.keyname}"
security_groups = ["https", "microk8s", "Allow SSH from SUNET jumphosts", "Allow ssh from the world"] security_groups = [
data.openstack_networking_secgroup_v2.sshfromjumphosts.name,
data.openstack_networking_secgroup_v2.allegress.name,
resource.openstack_networking_secgroup_v2.microk8s.name
]
block_device { block_device {
uuid = "5d24aca9-11be-4de1-9770-4a097d68f361" uuid = resource.openstack_blockstorage_volume_v3.kubecvolumeboot[count.index].id
source_type = "image" source_type = "volume"
volume_size = 20
boot_index = 0
destination_type = "volume" destination_type = "volume"
delete_on_termination = true boot_index = 0
} }
scheduler_hints { scheduler_hints {
group = openstack_compute_servergroup_v2.controllers.id group = openstack_compute_servergroup_v2.controllers.id
} }
network { network {
name = "public" port = resource.openstack_networking_port_v2.kubeport[count.index].id
} }
} }
#
# Worker node resources
#
resource "openstack_compute_instance_v2" "worker-nodes" { resource "openstack_compute_instance_v2" "worker-nodes" {
count = var.worker_instance_count count = var.worker_instance_count
name = "${var.worker_name}-${count.index}.${var.dns_suffix}" name = "${var.worker_name}-${count.index}.${var.dns_suffix}"

View file

@ -1,3 +1,17 @@
# Datasource of sunet ssh-from-jumphost security group.
data "openstack_networking_secgroup_v2" "sshfromjumphosts" {
name = "ssh-from-jumphost"
}
data "openstack_networking_secgroup_v2" "allegress" {
name = "allegress"
}
resource "openstack_networking_secgroup_v2" "microk8s" {
name = "microk8s"
description = "Traffic to allow between microk8s hosts"
}
resource "openstack_networking_secgroup_rule_v2" "microk8s_rule1" { resource "openstack_networking_secgroup_rule_v2" "microk8s_rule1" {
#We never know where Richard is, so allow from all of the known internet #We never know where Richard is, so allow from all of the known internet
direction = "ingress" direction = "ingress"

View file

@ -7,7 +7,3 @@ resource "openstack_compute_servergroup_v2" "controllers" {
policies = ["anti-affinity"] policies = ["anti-affinity"]
} }
resource "openstack_networking_secgroup_v2" "microk8s" {
name = "microk8s"
description = "Traffic to allow between microk8s hosts"
}

View file

@ -18,18 +18,19 @@ variable "controller_instance_count" {
variable "controller_instance_type" { variable "controller_instance_type" {
default = "b2.c2r4" default = "b2.c2r4"
} }
variable "monitor_instance_type" {
default = "b2.c2r4"
}
variable "worker_instance_type" { variable "worker_instance_type" {
default = "b2.c4r16" default = "b2.c4r16"
} }
variable "worker_name" { variable "worker_name" {
default = "internal-sto4-test-k8sw" default = "k8sw"
} }
variable "controller_name" { variable "controller_name" {
default = "internal-sto4-test-k8sc" default = "k8sc"
} }
variable "dns_suffix" { variable "dns_suffix" {
default = "rut.sunet.se" default = "matrix-test.sunet.se"
} }