diff --git a/modules/kubernetes/dbaas/main.tf b/modules/kubernetes/dbaas/main.tf index af4bd360..6697039a 100644 --- a/modules/kubernetes/dbaas/main.tf +++ b/modules/kubernetes/dbaas/main.tf @@ -898,3 +898,54 @@ resource "kubernetes_ingress_v1" "pgadmin" { } } } + +resource "kubernetes_cron_job_v1" "postgresql-backup" { + metadata { + name = "postgresql-backup" + namespace = "dbaas" + } + spec { + concurrency_policy = "Replace" + failed_jobs_history_limit = 5 + schedule = "0 */6 * * *" + # schedule = "* * * * *" + starting_deadline_seconds = 10 + successful_jobs_history_limit = 10 + job_template { + metadata {} + spec { + backoff_limit = 3 + ttl_seconds_after_finished = 10 + template { + metadata {} + spec { + container { + name = "postgresql-backup" + image = "postgres:16.4-bullseye" + command = ["/bin/sh", "-c", <<-EOT + export now=$(date +"%Y_%m_%d_%H_%M") + PGPASSWORD=${var.postgresql_root_password} pg_dumpall -h postgresql.dbaas -U root > /backup/dump_$now.sql + + # Rotate - delete last log file + cd /backup + find . -name "dump_*.sql" -type f -mtime +14 -delete # 14 day retention of backups + EOT + ] + volume_mount { + name = "postgresql-backup" + mount_path = "/backup" + } + } + volume { + name = "postgresql-backup" + nfs { + path = "/mnt/main/postgresql-backup" + server = "10.0.10.15" + } + } + } + } + } + } + } +} diff --git a/terraform.tfstate b/terraform.tfstate index 3b680965..32f857b5 100644 Binary files a/terraform.tfstate and b/terraform.tfstate differ