variable "tls_secret_name" {} variable "tier" { type = string } # variable "dockerhub_password" {} resource "kubernetes_namespace" "website" { metadata { name = "website" labels = { "istio-injection" : "disabled" } } } module "tls_secret" { source = "../setup_tls_secret" namespace = kubernetes_namespace.website.metadata[0].name tls_secret_name = var.tls_secret_name } # module "dockerhub_creds" { # source = "../dockerhub_secret" # namespace = kubernetes_namespace.website.metadata[0].name # password = var.dockerhub_password # } resource "kubernetes_deployment" "blog" { metadata { name = "blog" namespace = kubernetes_namespace.website.metadata[0].name labels = { run = "blog" tier = var.tier } } spec { replicas = 3 selector { match_labels = { run = "blog" } } template { metadata { labels = { run = "blog" } } spec { container { image = "viktorbarzin/blog:latest" name = "blog" resources { limits = { cpu = "0.5" memory = "512Mi" } requests = { cpu = "250m" memory = "50Mi" } } port { container_port = 80 } } container { image = "nginx/nginx-prometheus-exporter" name = "nginx-exporter" args = ["-nginx.scrape-uri", "http://127.0.0.1:8080/nginx_status"] port { container_port = 9113 } } } } } } resource "kubernetes_service" "blog" { metadata { name = "blog" namespace = kubernetes_namespace.website.metadata[0].name labels = { "run" = "blog" } annotations = { "prometheus.io/scrape" = "true" "prometheus.io/path" = "/metrics" "prometheus.io/port" = "9113" } } spec { selector = { run = "blog" } port { name = "http" port = "80" target_port = "80" } port { name = "prometheus" port = "9113" target_port = "9113" } } } resource "kubernetes_ingress_v1" "blog" { metadata { name = "blog-ingress" namespace = kubernetes_namespace.website.metadata[0].name annotations = { "traefik.ingress.kubernetes.io/router.middlewares" = "traefik-rate-limit@kubernetescrd,traefik-csp-headers@kubernetescrd,traefik-crowdsec@kubernetescrd,website-rybbit-analytics@kubernetescrd" "traefik.ingress.kubernetes.io/router.entrypoints" = "websecure" } } spec { ingress_class_name = "traefik" tls { hosts = ["viktorbarzin.me"] secret_name = var.tls_secret_name } rule { host = "viktorbarzin.me" http { path { path = "/" backend { service { name = "blog" port { number = 80 } } } } } } rule { host = "www.viktorbarzin.me" http { path { path = "/" backend { service { name = "blog" port { number = 80 } } } } } } } } # Rybbit analytics middleware for blog resource "kubernetes_manifest" "rybbit_analytics" { manifest = { apiVersion = "traefik.io/v1alpha1" kind = "Middleware" metadata = { name = "rybbit-analytics" namespace = kubernetes_namespace.website.metadata[0].name } spec = { plugin = { rewritebody = { rewrites = [{ regex = "" replacement = "" }] } } } } }