# -------------------------------------------------- # PersistentVolume (local disk on mist) — PROD # -------------------------------------------------- apiVersion: v1 kind: PersistentVolume metadata: name: postgres-prod-pv spec: capacity: storage: 20Gi accessModes: - ReadWriteOnce persistentVolumeReclaimPolicy: Retain storageClassName: local-storage hostPath: path: /home/kimjunte/k8s_storage/postgres/stripe_invoice_prod --- # -------------------------------------------------- # PersistentVolumeClaim — PROD # -------------------------------------------------- apiVersion: v1 kind: PersistentVolumeClaim metadata: name: postgres-prod-pvc namespace: default spec: accessModes: - ReadWriteOnce resources: requests: storage: 20Gi storageClassName: local-storage --- # -------------------------------------------------- # PostgreSQL Secret — PROD # (DO NOT COMMIT real values) # -------------------------------------------------- apiVersion: v1 kind: Secret metadata: name: postgres-prod-secret namespace: default type: Opaque stringData: POSTGRES_USER: stripe_invoice_prod POSTGRES_PASSWORD: productionPassword1142M@ke!tH@rd2Br3akWith$ymb0ls POSTGRES_DB: stripe_invoice_prod --- # -------------------------------------------------- # PostgreSQL Deployment — PROD # -------------------------------------------------- apiVersion: apps/v1 kind: Deployment metadata: name: postgres-prod namespace: default spec: replicas: 1 selector: matchLabels: app: postgres-prod template: metadata: labels: app: postgres-prod spec: containers: - name: postgres image: postgres:16 ports: - containerPort: 5432 envFrom: - secretRef: name: postgres-prod-secret volumeMounts: - name: postgres-data mountPath: /var/lib/postgresql/data readinessProbe: tcpSocket: port: 5432 initialDelaySeconds: 10 periodSeconds: 5 livenessProbe: tcpSocket: port: 5432 initialDelaySeconds: 30 periodSeconds: 10 volumes: - name: postgres-data persistentVolumeClaim: claimName: postgres-prod-pvc --- # -------------------------------------------------- # PostgreSQL Service (cluster-internal only) — PROD # -------------------------------------------------- apiVersion: v1 kind: Service metadata: name: postgres-prod namespace: default spec: type: ClusterIP selector: app: postgres-prod ports: - port: 5432 targetPort: 5432