2026-01-12 21:22:54 -03:00
|
|
|
# services/planka/deployment.yaml
|
|
|
|
|
apiVersion: apps/v1
|
|
|
|
|
kind: Deployment
|
|
|
|
|
metadata:
|
|
|
|
|
name: planka
|
|
|
|
|
namespace: planka
|
|
|
|
|
labels:
|
|
|
|
|
app: planka
|
|
|
|
|
spec:
|
|
|
|
|
replicas: 1
|
|
|
|
|
selector:
|
|
|
|
|
matchLabels:
|
|
|
|
|
app: planka
|
|
|
|
|
strategy:
|
|
|
|
|
type: RollingUpdate
|
|
|
|
|
rollingUpdate:
|
|
|
|
|
maxSurge: 0
|
|
|
|
|
maxUnavailable: 1
|
|
|
|
|
template:
|
|
|
|
|
metadata:
|
|
|
|
|
labels:
|
|
|
|
|
app: planka
|
|
|
|
|
spec:
|
|
|
|
|
nodeSelector:
|
|
|
|
|
node-role.kubernetes.io/worker: "true"
|
|
|
|
|
affinity:
|
|
|
|
|
nodeAffinity:
|
|
|
|
|
requiredDuringSchedulingIgnoredDuringExecution:
|
|
|
|
|
nodeSelectorTerms:
|
|
|
|
|
- matchExpressions:
|
|
|
|
|
- key: hardware
|
|
|
|
|
operator: In
|
|
|
|
|
values: ["rpi4", "rpi5"]
|
|
|
|
|
securityContext:
|
|
|
|
|
runAsUser: 1000
|
|
|
|
|
runAsGroup: 1000
|
|
|
|
|
fsGroup: 1000
|
|
|
|
|
fsGroupChangePolicy: OnRootMismatch
|
2026-01-12 21:45:00 -03:00
|
|
|
initContainers:
|
|
|
|
|
- name: init-user-data
|
|
|
|
|
image: docker.io/alpine:3.20
|
2026-01-12 22:02:07 -03:00
|
|
|
securityContext:
|
|
|
|
|
runAsUser: 0
|
|
|
|
|
runAsGroup: 0
|
2026-01-12 21:45:00 -03:00
|
|
|
command: ["/bin/sh", "-c"]
|
|
|
|
|
args:
|
|
|
|
|
- |
|
|
|
|
|
set -e
|
2026-01-12 22:47:23 -03:00
|
|
|
mkdir -p /data/public/user-avatars \
|
|
|
|
|
/data/public/background-images \
|
|
|
|
|
/data/private/attachments
|
|
|
|
|
chown -R 1000:1000 /data /tmp-data
|
2026-01-12 21:45:00 -03:00
|
|
|
volumeMounts:
|
|
|
|
|
- name: user-data
|
2026-01-12 22:47:23 -03:00
|
|
|
mountPath: /data
|
2026-01-12 21:45:00 -03:00
|
|
|
- name: app-data
|
2026-01-12 22:47:23 -03:00
|
|
|
mountPath: /tmp-data
|
2026-01-12 21:22:54 -03:00
|
|
|
containers:
|
|
|
|
|
- name: planka
|
|
|
|
|
image: ghcr.io/plankanban/planka:2.0.0-rc.4
|
|
|
|
|
ports:
|
|
|
|
|
- name: http
|
|
|
|
|
containerPort: 1337
|
|
|
|
|
env:
|
|
|
|
|
- name: BASE_URL
|
|
|
|
|
value: https://tasks.bstein.dev
|
|
|
|
|
- name: TRUST_PROXY
|
|
|
|
|
value: "true"
|
2026-01-12 23:13:30 -03:00
|
|
|
- name: OIDC_IGNORE_ROLES
|
|
|
|
|
value: "false"
|
2026-01-12 23:24:09 -03:00
|
|
|
- name: OIDC_ADMIN_ROLES
|
|
|
|
|
value: admin
|
2026-01-12 23:13:30 -03:00
|
|
|
- name: OIDC_PROJECT_OWNER_ROLES
|
2026-01-12 23:24:09 -03:00
|
|
|
value: planka-users
|
2026-01-12 23:13:30 -03:00
|
|
|
- name: OIDC_ROLES_ATTRIBUTE
|
|
|
|
|
value: groups
|
2026-01-12 21:22:54 -03:00
|
|
|
envFrom:
|
|
|
|
|
- secretRef:
|
|
|
|
|
name: planka-db
|
|
|
|
|
- secretRef:
|
|
|
|
|
name: planka-secrets
|
|
|
|
|
- secretRef:
|
|
|
|
|
name: planka-oidc
|
|
|
|
|
- secretRef:
|
|
|
|
|
name: planka-smtp
|
|
|
|
|
volumeMounts:
|
|
|
|
|
- name: user-data
|
2026-01-12 22:47:23 -03:00
|
|
|
mountPath: /app/public/user-avatars
|
|
|
|
|
subPath: public/user-avatars
|
|
|
|
|
- name: user-data
|
|
|
|
|
mountPath: /app/public/background-images
|
|
|
|
|
subPath: public/background-images
|
2026-01-12 21:22:54 -03:00
|
|
|
- name: user-data
|
2026-01-12 22:47:23 -03:00
|
|
|
mountPath: /app/private/attachments
|
|
|
|
|
subPath: private/attachments
|
2026-01-12 21:22:54 -03:00
|
|
|
- name: app-data
|
|
|
|
|
mountPath: /app/.tmp
|
|
|
|
|
readinessProbe:
|
|
|
|
|
httpGet:
|
|
|
|
|
path: /
|
|
|
|
|
port: http
|
|
|
|
|
initialDelaySeconds: 10
|
|
|
|
|
periodSeconds: 10
|
|
|
|
|
timeoutSeconds: 3
|
|
|
|
|
failureThreshold: 6
|
|
|
|
|
livenessProbe:
|
|
|
|
|
httpGet:
|
|
|
|
|
path: /
|
|
|
|
|
port: http
|
|
|
|
|
initialDelaySeconds: 30
|
|
|
|
|
periodSeconds: 20
|
|
|
|
|
timeoutSeconds: 3
|
|
|
|
|
failureThreshold: 6
|
|
|
|
|
resources:
|
|
|
|
|
requests:
|
|
|
|
|
cpu: 200m
|
|
|
|
|
memory: 512Mi
|
|
|
|
|
limits:
|
|
|
|
|
cpu: "1"
|
|
|
|
|
memory: 2Gi
|
|
|
|
|
volumes:
|
|
|
|
|
- name: user-data
|
|
|
|
|
persistentVolumeClaim:
|
|
|
|
|
claimName: planka-user-data
|
|
|
|
|
- name: app-data
|
|
|
|
|
persistentVolumeClaim:
|
|
|
|
|
claimName: planka-app-data
|