Compare commits
13 Commits
feat/nginx
...
096008617d
| Author | SHA1 | Date | |
|---|---|---|---|
| 096008617d | |||
|
|
128857d740 | ||
|
|
a74380c917 | ||
|
|
e0ef0e683f | ||
|
|
7fec458a39 | ||
| a09690feba | |||
|
|
cdb736d5b2 | ||
|
|
e9823e56ad | ||
|
|
d906dd2d25 | ||
|
|
ebef2bf36e | ||
|
|
9447fe8b01 | ||
|
|
539483b4b5 | ||
| 047b1cbde8 |
12
apps/nginx-canary/certificate.yaml
Normal file
12
apps/nginx-canary/certificate.yaml
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
apiVersion: cert-manager.io/v1
|
||||||
|
kind: Certificate
|
||||||
|
metadata:
|
||||||
|
name: nginx-canary-tls
|
||||||
|
namespace: nginx-canary
|
||||||
|
spec:
|
||||||
|
secretName: nginx-canary-tls
|
||||||
|
issuerRef:
|
||||||
|
name: letsencrypt-http
|
||||||
|
kind: ClusterIssuer
|
||||||
|
dnsNames:
|
||||||
|
- nginx-canary.thedevops.dev
|
||||||
37
apps/nginx-canary/ingressroute.yaml
Normal file
37
apps/nginx-canary/ingressroute.yaml
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
---
|
||||||
|
# Direct HTTPS access to canary app at nginx-canary.thedevops.dev
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: nginx-canary-direct
|
||||||
|
namespace: nginx-canary
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- websecure
|
||||||
|
routes:
|
||||||
|
- match: Host(`nginx-canary.thedevops.dev`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: nginx-canary
|
||||||
|
port: 80
|
||||||
|
tls:
|
||||||
|
secretName: nginx-canary-tls
|
||||||
|
---
|
||||||
|
# HTTP redirect for nginx-canary.thedevops.dev
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: nginx-canary-direct-http
|
||||||
|
namespace: nginx-canary
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- web
|
||||||
|
routes:
|
||||||
|
- match: Host(`nginx-canary.thedevops.dev`)
|
||||||
|
kind: Rule
|
||||||
|
middlewares:
|
||||||
|
- name: redirect-https
|
||||||
|
namespace: nginx-mcp
|
||||||
|
services:
|
||||||
|
- name: nginx-canary
|
||||||
|
port: 80
|
||||||
20
apps/nginx-weighted/application.yaml
Normal file
20
apps/nginx-weighted/application.yaml
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: nginx-weighted
|
||||||
|
namespace: argocd
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
source:
|
||||||
|
repoURL: http://gitea-http.gitea.svc.cluster.local:3000/admin/k3s-gitops
|
||||||
|
path: apps/nginx-weighted
|
||||||
|
targetRevision: HEAD
|
||||||
|
destination:
|
||||||
|
server: https://kubernetes.default.svc
|
||||||
|
namespace: nginx-mcp
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
prune: true
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
||||||
18
apps/nginx-weighted/canary-proxy-svc.yaml
Normal file
18
apps/nginx-weighted/canary-proxy-svc.yaml
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: nginx-canary-proxy
|
||||||
|
namespace: nginx-mcp
|
||||||
|
labels:
|
||||||
|
app: nginx-canary-proxy
|
||||||
|
annotations:
|
||||||
|
description: >
|
||||||
|
ExternalName proxy required because Traefik v3 does not allow
|
||||||
|
cross-namespace service references inside TraefikService weighted config.
|
||||||
|
This service bridges nginx-mcp namespace → nginx-canary namespace.
|
||||||
|
spec:
|
||||||
|
type: ExternalName
|
||||||
|
externalName: nginx-canary.nginx-canary.svc.cluster.local
|
||||||
|
ports:
|
||||||
|
- port: 80
|
||||||
|
targetPort: 80
|
||||||
12
apps/nginx-weighted/certificate-stable.yaml
Normal file
12
apps/nginx-weighted/certificate-stable.yaml
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
apiVersion: cert-manager.io/v1
|
||||||
|
kind: Certificate
|
||||||
|
metadata:
|
||||||
|
name: nginx-stable-tls
|
||||||
|
namespace: nginx-mcp
|
||||||
|
spec:
|
||||||
|
secretName: nginx-stable-tls
|
||||||
|
issuerRef:
|
||||||
|
name: letsencrypt-http
|
||||||
|
kind: ClusterIssuer
|
||||||
|
dnsNames:
|
||||||
|
- nginx-stable.thedevops.dev
|
||||||
12
apps/nginx-weighted/certificate.yaml
Normal file
12
apps/nginx-weighted/certificate.yaml
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
apiVersion: cert-manager.io/v1
|
||||||
|
kind: Certificate
|
||||||
|
metadata:
|
||||||
|
name: nginx-weighted-tls
|
||||||
|
namespace: nginx-mcp
|
||||||
|
spec:
|
||||||
|
secretName: nginx-weighted-tls
|
||||||
|
issuerRef:
|
||||||
|
name: letsencrypt-http
|
||||||
|
kind: ClusterIssuer
|
||||||
|
dnsNames:
|
||||||
|
- nginx.thedevops.dev
|
||||||
37
apps/nginx-weighted/ingressroute-stable.yaml
Normal file
37
apps/nginx-weighted/ingressroute-stable.yaml
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
---
|
||||||
|
# Direct HTTPS access to stable app at nginx-stable.thedevops.dev
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: nginx-stable-direct
|
||||||
|
namespace: nginx-mcp
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- websecure
|
||||||
|
routes:
|
||||||
|
- match: Host(`nginx-stable.thedevops.dev`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: nginx-mcp
|
||||||
|
port: 80
|
||||||
|
tls:
|
||||||
|
secretName: nginx-stable-tls
|
||||||
|
---
|
||||||
|
# HTTP redirect for nginx-stable.thedevops.dev
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: nginx-stable-direct-http
|
||||||
|
namespace: nginx-mcp
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- web
|
||||||
|
routes:
|
||||||
|
- match: Host(`nginx-stable.thedevops.dev`)
|
||||||
|
kind: Rule
|
||||||
|
middlewares:
|
||||||
|
- name: redirect-https
|
||||||
|
namespace: nginx-mcp
|
||||||
|
services:
|
||||||
|
- name: nginx-mcp
|
||||||
|
port: 80
|
||||||
38
apps/nginx-weighted/ingressroute.yaml
Normal file
38
apps/nginx-weighted/ingressroute.yaml
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
---
|
||||||
|
# HTTPS entrypoint — routes nginx.thedevops.dev through weighted TraefikService
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: nginx-weighted
|
||||||
|
namespace: nginx-mcp
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- websecure
|
||||||
|
routes:
|
||||||
|
- match: Host(`nginx.thedevops.dev`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: nginx-weighted
|
||||||
|
namespace: nginx-mcp
|
||||||
|
kind: TraefikService
|
||||||
|
tls:
|
||||||
|
secretName: nginx-weighted-tls
|
||||||
|
---
|
||||||
|
# HTTP entrypoint — redirects all HTTP traffic to HTTPS via middleware
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: nginx-weighted-http
|
||||||
|
namespace: nginx-mcp
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- web
|
||||||
|
routes:
|
||||||
|
- match: Host(`nginx.thedevops.dev`)
|
||||||
|
kind: Rule
|
||||||
|
middlewares:
|
||||||
|
- name: redirect-https
|
||||||
|
namespace: nginx-mcp
|
||||||
|
services:
|
||||||
|
- name: nginx-mcp
|
||||||
|
port: 80
|
||||||
9
apps/nginx-weighted/middleware.yaml
Normal file
9
apps/nginx-weighted/middleware.yaml
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: Middleware
|
||||||
|
metadata:
|
||||||
|
name: redirect-https
|
||||||
|
namespace: nginx-mcp
|
||||||
|
spec:
|
||||||
|
redirectScheme:
|
||||||
|
scheme: https
|
||||||
|
permanent: true
|
||||||
25
apps/nginx-weighted/traefikservice.yaml
Normal file
25
apps/nginx-weighted/traefikservice.yaml
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
---
|
||||||
|
# TraefikService — weighted load balancer between stable and canary.
|
||||||
|
# THIS IS THE ONLY FILE YOU NEED TO EDIT to shift traffic weights.
|
||||||
|
#
|
||||||
|
# Weight scenarios:
|
||||||
|
# Initial canary test → stable: 90 canary: 10
|
||||||
|
# Extended testing → stable: 50 canary: 50
|
||||||
|
# Full promote to canary → stable: 0 canary: 100
|
||||||
|
# Emergency rollback → stable: 100 canary: 0
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: TraefikService
|
||||||
|
metadata:
|
||||||
|
name: nginx-weighted
|
||||||
|
namespace: nginx-mcp
|
||||||
|
spec:
|
||||||
|
weighted:
|
||||||
|
services:
|
||||||
|
- name: nginx-mcp
|
||||||
|
namespace: nginx-mcp
|
||||||
|
port: 80
|
||||||
|
weight: 90
|
||||||
|
- name: nginx-canary-proxy
|
||||||
|
namespace: nginx-mcp
|
||||||
|
port: 80
|
||||||
|
weight: 10
|
||||||
Reference in New Issue
Block a user