# Synapse DB Init Job # Creates synapse database and user in PostgreSQL. # Synapse requires UTF-8 encoding and C locale — standard CREATE DATABASE won't work. # Run once before deploying Synapse. # # Deploy: # kubectl create secret generic synapse-secret \ # --namespace \ # --from-literal=db-password='' # kubectl apply -f synapse-db-init.yaml -n # # Watch completion: # kubectl get jobs -n -w # kubectl logs job/synapse-db-init -n apiVersion: batch/v1 kind: Job metadata: name: synapse-db-init spec: template: spec: restartPolicy: OnFailure containers: - name: synapse-db-init image: postgres:16 env: - name: PGPASSWORD valueFrom: secretKeyRef: name: postgres-secret key: password - name: SYNAPSE_DB_PASSWORD valueFrom: secretKeyRef: name: synapse-secret key: db-password command: - /bin/sh - -c - | psql -h postgres -U postgres <