fix: optimize Helm chart for landing page
Some checks failed
CI / test (3.12) (push) Has been cancelled
CI / security (push) Has been cancelled
ci/woodpecker/push/woodpecker Pipeline failed
CD - Build & Deploy / build-and-push (push) Has been cancelled
CD - Build & Deploy / package-helm (push) Has been cancelled
CD - Build & Deploy / deploy-staging (push) Has been cancelled
CD - Build & Deploy / deploy-production (push) Has been cancelled
CD - Build & Deploy / release (push) Has been cancelled
CI / test (3.11) (push) Has been cancelled

- Remove duplicate application-credentials.yaml template
- Fix Reflex environment: production -> prod, staging -> dev
- Switch from Nginx to Traefik ingress controller
- Optimize resources for simple landing page (1 replica, minimal CPU/RAM)
- Disable autoscaling and PDB for landing page
- Add registry credentials for hub.peikarband.ir
- Clean up secrets configuration
This commit is contained in:
Ehsan.Asadi
2025-12-30 17:10:56 +03:30
parent 3d0de7e55e
commit 11e96c82d6
4 changed files with 32 additions and 45 deletions

View File

@@ -1,14 +0,0 @@
{{- if .Values.appSecrets.enabled }}
apiVersion: v1
kind: Secret
metadata:
name: {{ .Values.appSecrets.name }}
labels:
{{- include "peikarband.labels" . | nindent 4 }}
type: Opaque
stringData:
db-username: {{ .Values.appSecrets.dbUsername | quote }}
db-password: {{ .Values.appSecrets.dbPassword | quote }}
redis-password: {{ .Values.appSecrets.redisPassword | quote }}
{{- end }}

View File

@@ -11,19 +11,19 @@ registrySecret:
enabled: true enabled: true
name: hub-registry-secret name: hub-registry-secret
server: hub.peikarband.ir server: hub.peikarband.ir
username: "admin" # Set via ArgoCD UI: Parameters → registrySecret.username username: "admin"
password: "5459ed7590d37656410fae38bdf59eb7ee33b68cd4c" # Set via ArgoCD UI: Parameters → registrySecret.password password: "5459ed7590d37656410fae38bdf59eb7ee33b68cd4c"
imagePullSecrets: imagePullSecrets:
- name: hub-registry-secret - name: hub-registry-secret
# Auto-create application secrets (database, redis, etc) # Auto-create application secrets (database, redis, etc)
appSecrets: appSecrets:
enabled: true enabled: false # Set to true if you need database/redis
name: peikarband-prod-secrets name: peikarband-prod-secrets
dbUsername: "REPLACE_ME" # Set via ArgoCD UI: Parameters → appSecrets.dbUsername dbUsername: ""
dbPassword: "REPLACE_ME" # Set via ArgoCD UI: Parameters → appSecrets.dbPassword dbPassword: ""
redisPassword: "REPLACE_ME" # Set via ArgoCD UI: Parameters → appSecrets.redisPassword redisPassword: ""
# Reflex configuration for production # Reflex configuration for production
reflex: reflex:
@@ -36,28 +36,28 @@ podAnnotations:
resources: resources:
limits: limits:
cpu: 500m
memory: 1Gi
requests:
cpu: 200m cpu: 200m
memory: 256Mi memory: 256Mi
requests:
cpu: 50m
memory: 128Mi
autoscaling: autoscaling:
enabled: false enabled: false
minReplicas: 3 minReplicas: 1
maxReplicas: 20 maxReplicas: 5
targetCPUUtilizationPercentage: 60 targetCPUUtilizationPercentage: 70
targetMemoryUtilizationPercentage: 70 targetMemoryUtilizationPercentage: 80
ingress: ingress:
enabled: true enabled: true
className: "nginx" className: "traefik"
annotations: annotations:
cert-manager.io/cluster-issuer: "letsencrypt-prod" cert-manager.io/cluster-issuer: "letsencrypt-prod"
nginx.ingress.kubernetes.io/ssl-redirect: "true" traefik.ingress.kubernetes.io/router.entrypoints: "websecure"
nginx.ingress.kubernetes.io/force-ssl-redirect: "true" traefik.ingress.kubernetes.io/router.tls: "true"
nginx.ingress.kubernetes.io/rate-limit: "100" # Rate limiting and body size should be configured via Traefik Middleware
nginx.ingress.kubernetes.io/proxy-body-size: "10m" # Example: traefik.ingress.kubernetes.io/router.middlewares: default-ratelimit@kubernetescrd
hosts: hosts:
- host: peikarband.ir - host: peikarband.ir
paths: paths:
@@ -99,11 +99,11 @@ configMap:
data: data:
APP_NAME: "peikarband" APP_NAME: "peikarband"
LOG_LEVEL: "warning" LOG_LEVEL: "warning"
ENVIRONMENT: "production" ENVIRONMENT: "prod"
podDisruptionBudget: podDisruptionBudget:
enabled: true enabled: false
minAvailable: 2 minAvailable: 1
networkPolicy: networkPolicy:
enabled: true enabled: true

View File

@@ -22,10 +22,11 @@ autoscaling:
ingress: ingress:
enabled: true enabled: true
className: "nginx" className: "traefik"
annotations: annotations:
cert-manager.io/cluster-issuer: "letsencrypt-staging" cert-manager.io/cluster-issuer: "letsencrypt-staging"
nginx.ingress.kubernetes.io/ssl-redirect: "true" traefik.ingress.kubernetes.io/router.entrypoints: "websecure"
traefik.ingress.kubernetes.io/router.tls: "true"
hosts: hosts:
- host: staging.peikarband.ir - host: staging.peikarband.ir
paths: paths:
@@ -53,7 +54,7 @@ configMap:
data: data:
APP_NAME: "peikarband-staging" APP_NAME: "peikarband-staging"
LOG_LEVEL: "debug" LOG_LEVEL: "debug"
ENVIRONMENT: "staging" ENVIRONMENT: "dev"
podDisruptionBudget: podDisruptionBudget:
enabled: false enabled: false

View File

@@ -15,8 +15,8 @@ registrySecret:
enabled: false # Set to true in production values enabled: false # Set to true in production values
name: hub-registry-secret name: hub-registry-secret
server: hub.peikarband.ir server: hub.peikarband.ir
username: "admin" # Set via ArgoCD values or --set username: "" # MUST be set via ArgoCD values or --set (DO NOT commit passwords)
password: "5459ed7590d37656410fae38bdf59eb7ee33b68cd4c" # Set via ArgoCD values or --set password: "" # MUST be set via ArgoCD values or --set (DO NOT commit passwords)
# Application secrets (database, redis, etc) # Application secrets (database, redis, etc)
appSecrets: appSecrets:
@@ -62,11 +62,11 @@ service:
ingress: ingress:
enabled: true enabled: true
className: "nginx" className: "traefik"
annotations: annotations:
cert-manager.io/cluster-issuer: "letsencrypt-prod" cert-manager.io/cluster-issuer: "letsencrypt-prod"
nginx.ingress.kubernetes.io/ssl-redirect: "true" traefik.ingress.kubernetes.io/router.entrypoints: "websecure"
nginx.ingress.kubernetes.io/force-ssl-redirect: "true" traefik.ingress.kubernetes.io/router.tls: "true"
hosts: hosts:
- host: peikarband.ir - host: peikarband.ir
paths: paths:
@@ -134,7 +134,7 @@ readinessProbe:
env: env:
- name: REFLEX_ENV - name: REFLEX_ENV
value: "production" value: "prod"
- name: PYTHONUNBUFFERED - name: PYTHONUNBUFFERED
value: "1" value: "1"
@@ -148,7 +148,7 @@ configMap:
data: data:
APP_NAME: "peikarband" APP_NAME: "peikarband"
LOG_LEVEL: "info" LOG_LEVEL: "info"
ENVIRONMENT: "production" ENVIRONMENT: "prod"
secretRef: secretRef:
name: "peikarband-secrets" name: "peikarband-secrets"