--- # tasks file for wordpress - name: Create WordPress namespace k8s: state: present definition: apiVersion: v1 kind: Namespace metadata: name: www - name: Create PVC for MySQL k8s: state: present definition: apiVersion: v1 kind: PersistentVolumeClaim metadata: name: mysql namespace: www spec: accessModes: - ReadWriteOnce resources: requests: storage: 64Gi - name: Create Deployment for MySQL k8s: state: present definition: apiVersion: v1 kind: Deployment metadata: name: mysql namespace: www 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: wordpress - name: MYSQL_USER value: wordpress - name: MYSQL_PASSWORD value: "{{ wordpress_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: www spec: selector: app: mysql ports: - port: 3306 name: mysql type: ClusterIP - name: Create PVC for WordPress k8s: state: present definition: apiVersion: v1 kind: PersistentVolumeClaim metadata: name: wordpress namespace: www spec: accessModes: - ReadWriteOnce resources: requests: storage: 128Gi - name: Create Deployment for WordPress k8s: state: present definition: apiVersion: v1 kind: Deployment metadata: name: wordpress namespace: www labels: app: wordpress spec: replicas: 1 selector: matchLabels: app: wordpress template: metadata: labels: app: wordpress spec: containers: - name: wordpress image: wordpress volumeMounts: - name: data mountPath: /var/www/html ports: - containerPort: 3000 env: - name: WORDPRESS_DB_HOST value: mysql - name: WORDPRESS_DB_NAME value: wordpress - name: WORDPRESS_DB_USER value: wordpress - name: WORDPRESS_DB_PASSWORD value: "{{ wordpress_mysql_password }}" volumes: - name: data persistentVolumeClaim: claimName: wordpress - name: Create Service for WordPress k8s: state: present definition: apiVersion: v1 kind: Service metadata: name: wordpress namespace: www spec: selector: app: wordpress 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: wordpress namespace: www spec: ingressClassName: nginx rules: - host: www.eom.dev http: paths: - pathType: Prefix path: / backend: service: name: wordpress port: number: 80 tls: - hosts: - www.eom.dev secretName: wordpress