--- # tasks file for deploy-redis.yml - name: Create persistent volume for redis k8s: state: present definition: apiVersion: v1 kind: PersistentVolume metadata: name: redis spec: capacity: storage: "{{ redis_storage }}" accessModes: - ReadWriteOnce persistentVolumeReclaimPolicy: Retain storageClassName: standard hostPath: path: "/data/store-0/eom/redis" nodeAffinity: required: nodeSelectorTerms: - matchExpressions: - key: kubernetes.io/hostname operator: In values: - alpha-worker-0 - name: Create persistent volume claim for redis k8s: state: present definition: apiVersion: v1 kind: PersistentVolumeClaim metadata: name: redis namespace: eom spec: accessModes: - ReadWriteOnce resources: requests: storage: "{{ redis_storage }}" storageClassName: standard volumeName: redis - name: Create a deployment k8s: definition: apiVersion: apps/v1 kind: Deployment metadata: name: redis namespace: eom spec: replicas: 1 selector: matchLabels: app: redis template: metadata: labels: app: redis spec: containers: - name: redis image: redis volumeMounts: - name: redis mountPath: /data ports: - containerPort: 6379 volumes: - name: redis persistentVolumeClaim: claimName: redis - name: Expose deployment as a service k8s: definition: apiVersion: v1 kind: Service metadata: name: redis namespace: eom spec: selector: app: redis ports: - port: 6379 protocol: TCP name: redis-port-6379 type: ClusterIP