From 22b5e47acb1fcc4e29fd2014faa6a1a14aac7e07 Mon Sep 17 00:00:00 2001 From: Shahab Dogar Date: Mon, 17 Nov 2025 12:35:29 +0500 Subject: [PATCH] fix: DevPy | kinda sorta HA --- devpy/manifest.yaml | 29 ++++++++++++++++++++++++++++- 1 file changed, 28 insertions(+), 1 deletion(-) diff --git a/devpy/manifest.yaml b/devpy/manifest.yaml index f2ea3f0..d18ea5f 100644 --- a/devpy/manifest.yaml +++ b/devpy/manifest.yaml @@ -18,7 +18,7 @@ metadata: name: devpi namespace: homelab spec: - replicas: 1 + replicas: 3 selector: matchLabels: app: devpi @@ -27,6 +27,28 @@ spec: labels: app: devpi spec: + nodeSelector: + nodepool: worker + + topologySpreadConstraints: + - maxSkew: 1 + topologyKey: kubernetes.io/hostname + whenUnsatisfiable: ScheduleAnyway + labelSelector: + matchLabels: + app: devpi + + affinity: + podAntiAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app + operator: In + values: + - devpi + topologyKey: "kubernetes.io/hostname" + containers: - name: devpi image: jonasal/devpi-server:latest @@ -70,6 +92,11 @@ metadata: cert-manager.io/cluster-issuer: "cloudflare-issuer" cert-manager.io/acme-challenge-type: "dns01" cert-manager.io/private-key-size: "4096" + + # NGINX IP-based rate limiting + nginx.ingress.kubernetes.io/limit-rps: "10" + nginx.ingress.kubernetes.io/limit-burst-multiplier: "5" + nginx.ingress.kubernetes.io/limit-whitelist: "127.0.0.1" spec: ingressClassName: nginx-internal tls: