Files
web-apps/jotion/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

# Jotion Web App Helm Values
name: jotion
image:
registry: ghcr.io
repository: mayne0213/jotion
tag: latest
pullPolicy: Always
imagePullSecrets:
- name: ghcr-secret
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: jotion0213.kro.kr
paths:
- path: /
pathType: Prefix
- host: www.jotion0213.kro.kr
paths:
- path: /
pathType: Prefix
tls:
- secretName: jotion-tls
hosts:
- jotion0213.kro.kr
- www.jotion0213.kro.kr
resources:
requests:
memory: 128Mi
cpu: 15m
limits:
memory: 128Mi
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: jotion-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: jotion
property: DATABASE_URL
# Affinity - Soft Anti-Affinity to spread pods across nodes
affinity:
podAntiAffinity:
preferredDuringSchedulingIgnoredDuringExecution:
- weight: 100
podAffinityTerm:
topologyKey: kubernetes.io/hostname