--- # tasks file for gitea - name: Create git namespace k8s: state: present definition: apiVersion: v1 kind: Namespace metadata: name: git - name: Create PVC for MySQL k8s: state: present definition: apiVersion: v1 kind: PersistentVolumeClaim metadata: name: mysql namespace: git spec: accessModes: - ReadWriteOnce resources: requests: storage: 64Gi - name: Create Deployment for MySQL k8s: state: present definition: apiVersion: v1 kind: Deployment metadata: name: mysql namespace: git 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: gitea - name: MYSQL_USER value: gitea - name: MYSQL_PASSWORD value: "{{ gitea_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: git spec: selector: app: mysql ports: - port: 3306 name: mysql type: ClusterIP - name: Create PVC for Gitea k8s: state: present definition: apiVersion: v1 kind: PersistentVolumeClaim metadata: name: gitea namespace: git spec: accessModes: - ReadWriteOnce resources: requests: storage: 128Gi - name: Create Deployment for Gitea k8s: state: present definition: apiVersion: v1 kind: Deployment metadata: name: gitea namespace: git labels: app: gitea spec: replicas: 1 selector: matchLabels: app: gitea template: metadata: labels: app: gitea spec: containers: - name: gitea image: gitea/gitea volumeMounts: - name: data mountPath: /data ports: - containerPort: 3000 - containerPort: 22 env: - name: GITEA__database__DB_TYPE value: mysql - name: GITEA__database__HOST value: mysql - name: GITEA__database__NAME value: gitea - name: GITEA__database__USER value: gitea - name: GITEA__database__PASSWD value: "{{ gitea_mysql_password }}" volumes: - name: data persistentVolumeClaim: claimName: gitea - name: Create Service for GitLab k8s: state: present definition: apiVersion: v1 kind: Service metadata: name: gitea namespace: git spec: selector: app: gitea ports: - port: 22 name: ssh - port: 80 targetPort: 3000 name: http type: LoadBalancer - name: Create Ingress k8s: state: present definition: apiVersion: networking.k8s.io/v1 kind: Ingress metadata: annotations: cert-manager.io/cluster-issuer: ca-issuer name: gitea namespace: git spec: ingressClassName: nginx rules: - host: git.eom.dev http: paths: - pathType: Prefix path: / backend: service: name: gitea port: number: 80 tls: - hosts: - git.eom.dev secretName: gitea