software-infrastructure/roles/ericomeehan.eom.dev/tasks/deploy-redis.yml
2024-07-19 22:06:03 -04:00

94 lines
2.1 KiB
YAML

---
# 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