diff --git a/deployments/kustomization.yaml b/deployments/kustomization.yaml index 2ba0859..ea3a20f 100644 --- a/deployments/kustomization.yaml +++ b/deployments/kustomization.yaml @@ -1,6 +1,9 @@ +--- apiVersion: kustomize.config.k8s.io/v1beta1 kind: Kustomization resources: - namespace/namespace.yaml - mariadb/ + - replicator/ + - nextcloud/ diff --git a/deployments/nextcloud/kustomization.yaml b/deployments/nextcloud/kustomization.yaml new file mode 100644 index 0000000..777fa28 --- /dev/null +++ b/deployments/nextcloud/kustomization.yaml @@ -0,0 +1,6 @@ +--- +apiVersion: kustomize.config.k8s.io/v1beta1 +kind: Kustomization + +resources: + - nextcloud.yaml diff --git a/deployments/nextcloud/nextcloud.yaml b/deployments/nextcloud/nextcloud.yaml new file mode 100644 index 0000000..6b72fda --- /dev/null +++ b/deployments/nextcloud/nextcloud.yaml @@ -0,0 +1,137 @@ +--- +apiVersion: v1 +kind: PersistentVolume +metadata: + name: nextcloud-pv +spec: + capacity: + storage: 10Gi + accessModes: + - ReadWriteOnce + persistentVolumeReclaimPolicy: Retain + storageClassName: local-path + hostPath: + path: /dpool/temp/Nextcloud +--- +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: nextcloud-pvc + namespace: home-server +spec: + accessModes: + - ReadWriteOnce + storageClassName: local-path + resources: + requests: + storage: 10Gi + volumeName: nextcloud-pv +--- +apiVersion: v1 +kind: Service +metadata: + name: nextcloud + namespace: home-server +spec: + ports: + - port: 80 + selector: + app: nextcloud +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: nextcloud + namespace: home-server +spec: + securityContext: + runAsUser: 1000 + runAsGroup: 1000 + fsGroup: 1000 + selector: + matchLabels: + app: nextcloud + template: + metadata: + labels: + app: nextcloud + spec: + containers: + - name: nextcloud + image: nextcloud:29 + env: + - name: MYSQL_PASSWORD + valueFrom: + secretKeyRef: + name: nextcloud-secrets + key: MYSQL_PASSWORD + - name: MYSQL_DATABASE + value: nextcloud + - name: MYSQL_USER + value: nextcloud + - name: MYSQL_HOST + value: mariadb + ports: + - containerPort: 80 + volumeMounts: + - name: nextcloud-data + mountPath: /var/www/html + securityContext: + runAsUser: 1000 + runAsGroup: 1000 + fsGroup: 1000 + volumes: + - name: nextcloud-data + persistentVolumeClaim: + claimName: nextcloud-pvc +--- +apiVersion: k8s.mariadb.com/v1alpha1 +kind: MariaDB +metadata: + name: nextcloud-db + namespace: home-server +spec: + rootPasswordSecretKeyRef: + name: nextcloud-secrets + key: MYSQL_ROOT_PASSWORD + database: nextcloud + username: nextcloud + passwordSecretKeyRef: + name: nextcloud-secrets + key: MYSQL_PASSWORD + image: mariadb:10.11 + storage: + size: 5Gi +--- +apiVersion: v1 +kind: Secret +metadata: + name: wildcard-hxme-net + namespace: home-server + annotations: + replicator.v1.mittwald.de/replicate-from: cert-manager/wildcard-hxme-net +--- +apiVersion: networking.k8s.io/v1 +kind: Ingress +metadata: + name: nextcloud + namespace: home-server + annotations: + external-dns.alpha.kubernetes.io/hostname: nc.hxme.net +spec: + tls: + - hosts: + - nc.hxme.net + secretName: wildcard-hxme-net + rules: + - host: nc.hxme.net + http: + paths: + - path: / + pathType: Prefix + backend: + service: + name: nextcloud + port: + number: 80 +