Files
bakery-ia/infrastructure/services/databases/demo-session-db.yaml

157 lines
3.8 KiB
YAML
Raw Normal View History

2025-09-27 11:18:13 +02:00
apiVersion: apps/v1
kind: Deployment
metadata:
2026-01-19 11:55:17 +01:00
name: demo-session-db
2025-09-27 11:18:13 +02:00
namespace: bakery-ia
labels:
2026-01-19 11:55:17 +01:00
app: demo-session-db
component: database
app.kubernetes.io/name: demo-session-db
app.kubernetes.io/part-of: bakery-forecasting-platform
2025-09-27 11:18:13 +02:00
spec:
replicas: 1
2026-01-19 11:55:17 +01:00
strategy:
type: Recreate
2025-09-27 11:18:13 +02:00
selector:
matchLabels:
2026-01-19 11:55:17 +01:00
app: demo-session-db
2025-09-27 11:18:13 +02:00
template:
metadata:
labels:
2026-01-19 11:55:17 +01:00
app: demo-session-db
component: database
2025-09-27 11:18:13 +02:00
spec:
2025-10-19 19:22:37 +02:00
securityContext:
fsGroup: 70
initContainers:
- name: fix-tls-permissions
2026-01-19 11:55:17 +01:00
image: busybox:1.36
2025-10-19 19:22:37 +02:00
securityContext:
runAsUser: 0
command: ['sh', '-c']
args:
- |
cp /tls-source/* /tls/
chmod 600 /tls/server-key.pem
chmod 644 /tls/server-cert.pem /tls/ca-cert.pem
chown 70:70 /tls/*
ls -la /tls/
volumeMounts:
- name: tls-certs-source
mountPath: /tls-source
readOnly: true
- name: tls-certs-writable
mountPath: /tls
2025-09-27 11:18:13 +02:00
containers:
- name: postgres
image: postgres:17-alpine
2025-09-27 11:18:13 +02:00
ports:
- containerPort: 5432
name: postgres
2026-01-19 11:55:17 +01:00
envFrom:
- configMapRef:
name: bakery-config
2025-09-27 11:18:13 +02:00
env:
- name: POSTGRES_USER
valueFrom:
secretKeyRef:
name: database-secrets
2026-01-19 11:55:17 +01:00
key: DEMO_SESSION_DB_USER
2025-09-27 11:18:13 +02:00
- name: POSTGRES_PASSWORD
valueFrom:
secretKeyRef:
name: database-secrets
2026-01-19 11:55:17 +01:00
key: DEMO_SESSION_DB_PASSWORD
- name: POSTGRES_DB
value: demo_session_db
2025-09-27 11:18:13 +02:00
- name: PGDATA
value: /var/lib/postgresql/data/pgdata
volumeMounts:
2026-01-19 11:55:17 +01:00
- name: demo-session-db-data
2025-09-27 11:18:13 +02:00
mountPath: /var/lib/postgresql/data
2025-10-19 19:22:37 +02:00
- name: tls-certs-writable
mountPath: /tls
readOnly: true
2025-09-27 11:18:13 +02:00
resources:
requests:
memory: "256Mi"
cpu: "100m"
limits:
memory: "512Mi"
2026-01-19 11:55:17 +01:00
cpu: "200m"
2025-09-27 11:18:13 +02:00
livenessProbe:
exec:
command:
2025-09-30 13:32:51 +02:00
- sh
- -c
2026-01-19 11:55:17 +01:00
- exec pg_isready -U "$POSTGRES_USER" -d "$POSTGRES_DB"
2025-09-27 11:18:13 +02:00
initialDelaySeconds: 30
periodSeconds: 10
2026-01-19 11:55:17 +01:00
timeoutSeconds: 5
failureThreshold: 6
2025-09-27 11:18:13 +02:00
readinessProbe:
exec:
command:
2025-09-30 13:32:51 +02:00
- sh
- -c
2026-01-19 11:55:17 +01:00
- exec pg_isready -U "$POSTGRES_USER" -d "$POSTGRES_DB"
2025-09-27 11:18:13 +02:00
initialDelaySeconds: 5
2026-01-19 11:55:17 +01:00
periodSeconds: 10
timeoutSeconds: 5
failureThreshold: 6
2025-09-27 11:18:13 +02:00
volumes:
2026-01-19 11:55:17 +01:00
- name: demo-session-db-data
2025-10-19 19:22:37 +02:00
persistentVolumeClaim:
2026-01-19 11:55:17 +01:00
claimName: demo-session-db-pvc
2025-10-19 19:22:37 +02:00
- name: tls-certs-source
secret:
secretName: postgres-tls
2026-01-19 11:55:17 +01:00
items:
- key: server-cert.pem
path: server-cert.pem
- key: server-key.pem
path: server-key.pem
- key: ca-cert.pem
path: ca-cert.pem
2025-10-19 19:22:37 +02:00
- name: tls-certs-writable
emptyDir: {}
2026-01-19 11:55:17 +01:00
2025-09-27 11:18:13 +02:00
---
apiVersion: v1
kind: Service
metadata:
2026-01-19 11:55:17 +01:00
name: demo-session-db-service
2025-09-27 11:18:13 +02:00
namespace: bakery-ia
labels:
2026-01-19 11:55:17 +01:00
app: demo-session-db
component: database
app.kubernetes.io/name: demo-session-db-service
app.kubernetes.io/part-of: bakery-forecasting-platform
2025-09-27 11:18:13 +02:00
spec:
type: ClusterIP
2026-01-19 11:55:17 +01:00
selector:
app: demo-session-db
2025-09-27 11:18:13 +02:00
ports:
2026-01-19 11:55:17 +01:00
- name: postgres
port: 5432
2025-09-27 11:18:13 +02:00
targetPort: 5432
2025-10-19 19:22:37 +02:00
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
2026-01-19 11:55:17 +01:00
name: demo-session-db-pvc
2025-10-19 19:22:37 +02:00
namespace: bakery-ia
labels:
2026-01-19 11:55:17 +01:00
app: demo-session-db
component: database
app.kubernetes.io/name: demo-session-db-pvc
app.kubernetes.io/part-of: bakery-forecasting-platform
2025-10-19 19:22:37 +02:00
spec:
accessModes:
2026-01-19 11:55:17 +01:00
- ReadWriteOnce
2025-10-19 19:22:37 +02:00
resources:
requests:
2026-01-19 11:55:17 +01:00
storage: 1Gi
storageClassName: standard