mirror of
https://github.com/coder/coder.git
synced 2025-07-12 00:14:10 +00:00
Closes https://github.com/coder/internal/issues/148 This has been validated to have working proxies with the `small` scenario. - [x] multi-region gcp infrastructure - [x] use cloudflare provider to automate dns entries - [x] automate proxy registration - [x] multi-regional proxies - [x] move scenarios into locals This excludes the infrastructure for `cert-manager` and `otel-collector` and those will be included in followup PRs.
161 lines
4.6 KiB
HCL
161 lines
4.6 KiB
HCL
resource "local_file" "kubernetes_template" {
|
|
filename = "${path.module}/.coderv2/templates/kubernetes/main.tf"
|
|
content = <<EOF
|
|
terraform {
|
|
required_providers {
|
|
coder = {
|
|
source = "coder/coder"
|
|
version = "~> 0.23.0"
|
|
}
|
|
kubernetes = {
|
|
source = "hashicorp/kubernetes"
|
|
version = "~> 2.30"
|
|
}
|
|
}
|
|
}
|
|
|
|
provider "coder" {}
|
|
|
|
provider "kubernetes" {
|
|
config_path = null # always use host
|
|
}
|
|
|
|
data "coder_workspace" "me" {}
|
|
data "coder_workspace_owner" "me" {}
|
|
|
|
resource "coder_agent" "main" {
|
|
os = "linux"
|
|
arch = "amd64"
|
|
}
|
|
|
|
resource "kubernetes_pod" "main" {
|
|
count = data.coder_workspace.me.start_count
|
|
metadata {
|
|
name = "coder-$${lower(data.coder_workspace_owner.me.name)}-$${lower(data.coder_workspace.me.name)}"
|
|
namespace = "${local.coder_namespace}"
|
|
labels = {
|
|
"app.kubernetes.io/name" = "coder-workspace"
|
|
"app.kubernetes.io/instance" = "coder-workspace-$${lower(data.coder_workspace_owner.me.name)}-$${lower(data.coder_workspace.me.name)}"
|
|
}
|
|
}
|
|
spec {
|
|
security_context {
|
|
run_as_user = "1000"
|
|
fs_group = "1000"
|
|
}
|
|
container {
|
|
name = "dev"
|
|
image = "${var.workspace_image}"
|
|
image_pull_policy = "Always"
|
|
command = ["sh", "-c", coder_agent.main.init_script]
|
|
security_context {
|
|
run_as_user = "1000"
|
|
}
|
|
env {
|
|
name = "CODER_AGENT_TOKEN"
|
|
value = coder_agent.main.token
|
|
}
|
|
resources {
|
|
requests = {
|
|
"cpu" = "${local.scenarios[var.scenario].workspaces.cpu_request}"
|
|
"memory" = "${local.scenarios[var.scenario].workspaces.mem_request}"
|
|
}
|
|
limits = {
|
|
"cpu" = "${local.scenarios[var.scenario].workspaces.cpu_limit}"
|
|
"memory" = "${local.scenarios[var.scenario].workspaces.mem_limit}"
|
|
}
|
|
}
|
|
}
|
|
|
|
affinity {
|
|
node_affinity {
|
|
required_during_scheduling_ignored_during_execution {
|
|
node_selector_term {
|
|
match_expressions {
|
|
key = "cloud.google.com/gke-nodepool"
|
|
operator = "In"
|
|
values = ["${google_container_node_pool.node_pool["primary_workspaces"].name}","${google_container_node_pool.node_pool["europe_workspaces"].name}","${google_container_node_pool.node_pool["asia_workspaces"].name}"]
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
EOF
|
|
}
|
|
|
|
resource "kubernetes_config_map" "template" {
|
|
provider = kubernetes.primary
|
|
|
|
metadata {
|
|
name = "coder-template"
|
|
namespace = kubernetes_namespace.coder_primary.metadata.0.name
|
|
}
|
|
|
|
data = {
|
|
"main.tf" = local_file.kubernetes_template.content
|
|
}
|
|
}
|
|
|
|
resource "kubernetes_job" "push_template" {
|
|
provider = kubernetes.primary
|
|
|
|
metadata {
|
|
name = "${var.name}-push-template"
|
|
namespace = kubernetes_namespace.coder_primary.metadata.0.name
|
|
labels = {
|
|
"app.kubernetes.io/name" = "${var.name}-push-template"
|
|
}
|
|
}
|
|
spec {
|
|
completions = 1
|
|
template {
|
|
metadata {}
|
|
spec {
|
|
affinity {
|
|
node_affinity {
|
|
required_during_scheduling_ignored_during_execution {
|
|
node_selector_term {
|
|
match_expressions {
|
|
key = "cloud.google.com/gke-nodepool"
|
|
operator = "In"
|
|
values = ["${google_container_node_pool.node_pool["primary_misc"].name}"]
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
container {
|
|
name = "cli"
|
|
image = "${var.coder_image_repo}:${var.coder_image_tag}"
|
|
command = [
|
|
"/opt/coder",
|
|
"--verbose",
|
|
"--url=${local.deployments.primary.url}",
|
|
"--token=${trimspace(data.local_file.api_key.content)}",
|
|
"templates",
|
|
"push",
|
|
"--directory=/home/coder/template",
|
|
"--yes",
|
|
"kubernetes"
|
|
]
|
|
volume_mount {
|
|
name = "coder-template"
|
|
mount_path = "/home/coder/template/main.tf"
|
|
sub_path = "main.tf"
|
|
}
|
|
}
|
|
volume {
|
|
name = "coder-template"
|
|
config_map {
|
|
name = kubernetes_config_map.template.metadata.0.name
|
|
}
|
|
}
|
|
restart_policy = "Never"
|
|
}
|
|
}
|
|
}
|
|
wait_for_completion = true
|
|
}
|