++working letsencrypt / staging setup!!!

This commit is contained in:
Nico Schottelius 2021-06-18 22:17:57 +02:00
parent cda1990935
commit 2c303122fb
2 changed files with 120 additions and 9 deletions

View file

@ -1,16 +1,43 @@
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: tls1-letsencrypt-certs
spec:
accessModes:
- ReadWriteMany
resources:
requests:
storage: 50Mi
storageClassName: rook-cephfs
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: tls1-webroot
spec:
accessModes:
- ReadWriteMany
resources:
requests:
storage: 100Mi
storageClassName: rook-cephfs
---
apiVersion: apps/v1 apiVersion: apps/v1
kind: Deployment kind: Deployment
metadata: metadata:
name: tls1 name: tls1-http
spec: spec:
selector: selector:
matchLabels: matchLabels:
app: tls1 app: tls1-nginx
ssl: no
replicas: 1 replicas: 1
template: template:
metadata: metadata:
labels: labels:
app: tls1 app: tls1-nginx
ssl: no
spec: spec:
containers: containers:
- name: nginx-80 - name: nginx-80
@ -20,6 +47,39 @@ spec:
volumeMounts: volumeMounts:
- name: nginx-config-80 - name: nginx-config-80
mountPath: "/etc/nginx/conf.d/" mountPath: "/etc/nginx/conf.d/"
- name: etcletsencrypt
mountPath: "/etc/letsencrypt"
- name: webroot
mountPath: "/usr/share/nginx/html"
volumes:
- name: nginx-config-80
configMap:
name: nginx-80-config
- name: etcletsencrypt
persistentVolumeClaim:
claimName: tls1-letsencrypt-certs
- name: webroot
persistentVolumeClaim:
claimName: tls1-webroot
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: tls1-https
spec:
selector:
matchLabels:
app: tls1-nginx
ssl: yes
replicas: 1
template:
metadata:
labels:
app: tls1-nginx
ssl: yes
spec:
containers:
- name: nginx-443 - name: nginx-443
image: nginx:1.20.0-alpine image: nginx:1.20.0-alpine
ports: ports:
@ -27,13 +87,21 @@ spec:
volumeMounts: volumeMounts:
- name: nginx-config-443 - name: nginx-config-443
mountPath: "/etc/nginx/conf.d/" mountPath: "/etc/nginx/conf.d/"
- name: etcletsencrypt
mountPath: "/etc/letsencrypt"
- name: webroot
mountPath: "/usr/share/nginx/html"
volumes: volumes:
- name: nginx-config-80
configMap:
name: nginx-80-config
- name: nginx-config-443 - name: nginx-config-443
configMap: configMap:
name: nginx-443-config name: nginx-443-config
- name: etcletsencrypt
persistentVolumeClaim:
claimName: tls1-letsencrypt-certs
- name: webroot
persistentVolumeClaim:
claimName: tls1-webroot
--- ---
apiVersion: v1 apiVersion: v1
kind: Service kind: Service
@ -45,6 +113,49 @@ spec:
type: ClusterIP type: ClusterIP
ports: ports:
- port: 80 - port: 80
name: http
- port: 443 - port: 443
name: https
selector: selector:
app: tls1-nginx app: tls1-nginx
---
apiVersion: batch/v1
kind: Job
metadata:
name: tls1-getcert
spec:
template:
spec:
restartPolicy: Never
containers:
- name: certbot
image: ungleich/ungleich-certbot
command:
- certbot
- certonly
- --agree-tos
- --cert-name
- 'tls1.default.svc.c2.k8s.ooo'
- --email
- sre@ungleich.ch
- --expand
- --non-interactive
- --webroot
- --webroot-path
- /usr/share/nginx/html
- --domain
- 'tls1.default.svc.c2.k8s.ooo'
- --staging
volumeMounts:
- name: etcletsencrypt
mountPath: "/etc/letsencrypt"
- name: webroot
mountPath: "/usr/share/nginx/html"
volumes:
- name: etcletsencrypt
persistentVolumeClaim:
claimName: tls1-letsencrypt-certs
- name: webroot
persistentVolumeClaim:
claimName: tls1-webroot
backoffLimit: 3

View file

@ -2,10 +2,10 @@ server {
listen 443 ssl; listen 443 ssl;
listen [::]:443 ssl; listen [::]:443 ssl;
server_name tls1.svc.c2.k8s.ooo; server_name tls1.default.svc.c2.k8s.ooo;
ssl_certificate /etc/letsencrypt/live/tls1.svc.c2.k8s.ooo/fullchain.pem; ssl_certificate /etc/letsencrypt/live/tls1.default.svc.c2.k8s.ooo/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/tls1.svc.c2.k8s.ooo/privkey.pem; ssl_certificate_key /etc/letsencrypt/live/tls1.default.svc.c2.k8s.ooo/privkey.pem;
client_max_body_size 256m; client_max_body_size 256m;