Files
web-apps/todo/helm-values.yaml
Mayne0213 7b006ad1bb CHORE(resources): set memory limits equal to memory requests
- Align memory limits with memory requests for guaranteed QoS class
- jotion, jovies, portfolio, todo
- web-app chart default values
2026-01-10 01:21:13 +09:00

93 lines
1.7 KiB
YAML

# Todo Web App Helm Values
name: todo
image:
registry: ghcr.io
repository: mayne0213/todo
tag: latest
pullPolicy: Always
# No imagePullSecrets needed (public or already configured)
imagePullSecrets: []
replicaCount: 2
containerPort: 3000
service:
enabled: true
type: ClusterIP
port: 80
ingress:
enabled: true
className: traefik
annotations:
cert-manager.io/cluster-issuer: letsencrypt-prod
hosts:
- host: todo0213.kro.kr
paths:
- path: /
pathType: Prefix
- host: www.todo0213.kro.kr
paths:
- path: /
pathType: Prefix
tls:
- secretName: todo-tls
hosts:
- todo0213.kro.kr
- www.todo0213.kro.kr
resources:
requests:
memory: 100Mi
cpu: 15m
limits:
memory: 100Mi
healthCheck:
enabled: true
path: /api/health
startupProbe:
periodSeconds: 10
failureThreshold: 30
livenessProbe:
initialDelaySeconds: 0
periodSeconds: 10
readinessProbe:
initialDelaySeconds: 0
periodSeconds: 5
env:
- name: NODE_ENV
value: production
- name: DATABASE_URL
valueFrom:
secretKeyRef:
name: todo-secrets
key: database-url
externalSecret:
enabled: true
refreshInterval: 1h
secretStoreRef:
name: vault-backend
kind: ClusterSecretStore
target:
creationPolicy: Owner
deletionPolicy: Retain
data:
- secretKey: database-url
remoteRef:
key: todo
property: DATABASE_URL
# Affinity - Soft Anti-Affinity to spread pods across nodes
affinity:
podAntiAffinity:
preferredDuringSchedulingIgnoredDuringExecution:
- weight: 100
podAffinityTerm:
topologyKey: kubernetes.io/hostname