--- # tasks file for nextcloud - name: Create NextCloud namespace k8s: state: present definition: apiVersion: v1 kind: Namespace metadata: name: cloud - name: Create PVC for MySQL k8s: state: present definition: apiVersion: v1 kind: PersistentVolumeClaim metadata: name: mysql namespace: cloud spec: accessModes: - ReadWriteOnce resources: requests: storage: 64Gi - name: Create Deployment for MySQL k8s: state: present definition: apiVersion: v1 kind: Deployment metadata: name: mysql namespace: cloud labels: app: mysql spec: replicas: 1 selector: matchLabels: app: mysql template: metadata: labels: app: mysql spec: containers: - name: mysql image: mysql volumeMounts: - name: data mountPath: /var/lib/mysql ports: - containerPort: 3306 env: - name: MYSQL_ROOT_PASSWORD value: "{{ mysql_root_password }}" - name: MYSQL_DATABASE value: nextcloud - name: MYSQL_USER value: nextcloud - name: MYSQL_PASSWORD value: "{{ nextcloud_mysql_password }}" volumes: - name: data persistentVolumeClaim: claimName: mysql - name: Create Service for MySQL k8s: state: present definition: apiVersion: v1 kind: Service metadata: name: mysql namespace: cloud spec: selector: app: mysql ports: - port: 3306 name: mysql type: ClusterIP - name: Create PVC for NextCloud k8s: state: present definition: apiVersion: v1 kind: PersistentVolumeClaim metadata: name: nextcloud namespace: cloud spec: accessModes: - ReadWriteOnce resources: requests: storage: 128Gi - name: Create Deployment for NextCloud k8s: state: present definition: apiVersion: v1 kind: Deployment metadata: name: nextcloud namespace: cloud labels: app: nextcloud spec: replicas: 1 selector: matchLabels: app: nextcloud template: metadata: labels: app: nextcloud spec: containers: - name: nextcloud image: nextcloud volumeMounts: - name: data mountPath: /var/www/html ports: - containerPort: 3000 env: - name: MYSQL_HOST value: mysql - name: MYSQL_DATABASE value: nextcloud - name: MYSQL_USER value: nextcloud - name: MYSQL_PASSWORD value: "{{ nextcloud_mysql_password }}" volumes: - name: data persistentVolumeClaim: claimName: nextcloud - name: Create Service for NextCloud k8s: state: present definition: apiVersion: v1 kind: Service metadata: name: nextcloud namespace: cloud spec: selector: app: nextcloud ports: - port: 80 name: http type: ClusterIP - name: Create Ingress k8s: state: present definition: apiVersion: networking.k8s.io/v1 kind: Ingress metadata: annotations: cert-manager.io/cluster-issuer: ca-issuer name: nextcloud namespace: cloud spec: ingressClassName: nginx rules: - host: cloud.eom.dev http: paths: - pathType: Prefix path: / backend: service: name: nextcloud port: number: 80 tls: - hosts: - cloud.eom.dev secretName: nextcloud