#we use postgresql: #create database gitea; #create user gitea with encrypted password 'secret'; #grant all privileges on database gitea to gitea; apiVersion: apps/v1 kind: Deployment metadata: name: gitea labels: app: gitea release: latest spec: replicas: 1 selector: matchLabels: app: gitea release: latest template: metadata: labels: app: gitea release: latest spec: containers: - name: gitea image: gitea/gitea:latest imagePullPolicy: Always env: - name: USER_UID value: "1000" - name: USER_GID value: "1000" - name: TZ value: "Europe/Berlin" - name: DB_TYPE value: postgres - name: DB_HOST value: postgres.live-env.svc.cluster.local:5432 - name: DB_NAME value: gitea - name: DB_USER value: gitea - name: DB_PASSWD value: giteaEu94XSS4gKpheSBoMsIs volumeMounts: - name: gitea mountPath: /data ports: - name: http containerPort: 3000 protocol: TCP - name: ssh containerPort: 22 protocol : TCP livenessProbe: httpGet: path: / port: http readinessProbe: httpGet: path: / port: http resources: requests: memory: "200Mi" cpu: "150m" limits: memory: "312Mi" cpu: "500m" volumes: - name: gitea persistentVolumeClaim: claimName: gitea --- apiVersion: v1 kind: PersistentVolumeClaim metadata: name: gitea labels: app: gitea spec: storageClassName: nfs-ssd accessModes: - ReadWriteOnce resources: requests: storage: 20Gi --- apiVersion: v1 kind: Service metadata: name: gitea labels: app: gitea spec: type: LoadBalancer loadBalancerIP: 172.23.255.2 ports: - port: 3000 targetPort: http protocol: TCP name: http - port: 22 targetPort: 22 name: ssh selector: app: gitea release: latest --- apiVersion: networking.k8s.io/v1 kind: Ingress metadata: name: gitea annotations: kubernetes.io/ingress.class: nginx ingress.kubernetes.io/whitelist-x-forwarded-for: "true" nginx.ingress.kubernetes.io/proxy-body-size: 512m spec: rules: - host: git-ui.lan http: paths: - path: / pathType: Prefix backend: service: name: gitea port: number: 3000