Merge pull request 'k8s: ajouter fichiers de déploiement de base' (#8) from vlbeaudoin/deploy/k8s into main

Reviewed-on: #8
This commit is contained in:
Victor Lacasse-Beaudoin 2025-03-13 18:55:01 -04:00
commit 9b63282dd9
4 changed files with 88 additions and 0 deletions

1
.gitignore vendored
View file

@ -1,2 +1,3 @@
.env .env
.swp .swp
k8s/prod.secret.yaml

45
k8s/deployment.yaml Normal file
View file

@ -0,0 +1,45 @@
apiVersion: apps/v1
kind: Deployment
metadata:
name: agendas-deployment
labels:
app: agendas
spec:
replicas: 1
selector:
matchLabels:
app: agendas
template:
metadata:
labels:
app: agendas
spec:
containers:
- name: agendas
image: git.agecem.com/bottin/agendas:latest
command: ['agendas', '--config', '/etc/agendas/config.yaml']
imagePullPolicy: Always
ports:
- containerPort: 3333
volumeMounts:
- name: config-secret
mountPath: '/etc/agendas/'
readOnly: true
- name: localtime
mountPath: /etc/localtime
readOnly: true
volumes:
- name: config-secret
secret:
secretName: agendas-config-secret
items:
- key: config.yaml
path: config.yaml
- key: cert.pem
path: cert.pem
- key: key.pem
path: key.pem
- name: localtime
hostPath:
path: /etc/localtime
type: File

31
k8s/example-secret.yaml Normal file
View file

@ -0,0 +1,31 @@
apiVersion: v1
kind: Secret
metadata:
name: agendas-config-secret
type: Opaque
stringData:
config.yaml: |
Bottin:
Host: 'api.bottin.agecem.com'
Key: 'CHANGE_ME'
Port: 443
TLS:
Enabled: true
SkipVerify: false
Credentials:
'agendas': 'CHANGE_ME'
DB:
Database: 'agendas'
Host: 'db'
Password: 'CHANGE_ME'
Port: 5432
SSLMode: 'prefer'
Username: 'agendas'
TLS:
Enabled: true
Cert: '/etc/agendas/cert.pem'
Key: '/etc/agendas/key.pem'
cert.pem: |
CHANGE_ME
key.pem: |
CHANGE_ME

11
k8s/service.yaml Normal file
View file

@ -0,0 +1,11 @@
apiVersion: v1
kind: Service
metadata:
name: agendas-service
spec:
type: NodePort
selector:
app: agendas
ports:
- protocol: TCP
port: 3333