browsertrix/backend/btrixcloud/templates/redis.yaml
Ilya Kreymer 7ea6d76f10
Resource Constraints Cleanup: (fixes #895) (#1019)
* resource constraints: (fixes #895)
- for cpu, only set cpu requests
- for memory, set mem requests == mem limits
- add missing resource constraints for minio and scheduled job
- for crawler, set mem and cpu constraints per browser, scale based on browser instances per crawler
- add comments in values.yaml for crawler values being multiplied
- default values: bump crawler to 650 millicpu per browser instance just in case

cleanup: remove unused entries from main backend configmap
2023-08-01 00:11:16 -07:00

138 lines
2.8 KiB
YAML

# --------
# REDIS
# --------
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: redis-{{ id }}
namespace: {{ namespace }}
labels:
crawl: {{ id }}
role: redis
spec:
selector:
matchLabels:
crawl: {{ id }}
role: redis
serviceName: redis-{{ id }}
replicas: {{ redis_scale }}
podManagementPolicy: Parallel
# not yet supported
#persistentVolumeClaimRetentionPolicy:
# whenDeleted: Delete
# whenScaled: Delete
volumeClaimTemplates:
- metadata:
name: redis-data
labels:
crawl: {{ id }}
role: redis
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 1Gi
{% if volume_storage_class %}
storageClassName: {{ volume_storage_class }}
{% endif %}
template:
metadata:
labels:
crawl: {{ id }}
role: redis
spec:
terminationGracePeriodSeconds: 10
#nodeSelector: {{ crawl_node_selector }}
volumes:
- name: shared-redis-conf
configMap:
name: shared-redis-conf
items:
- key: redis.conf
path: redis.conf
affinity:
nodeAffinity:
preferredDuringSchedulingIgnoredDuringExecution:
- weight: 1
preference:
matchExpressions:
- key: nodeType
operator: In
values:
- "{{ redis_node_type }}"
podAffinity:
preferredDuringSchedulingIgnoredDuringExecution:
- weight: 2
podAffinityTerm:
topologyKey: "failure-domain.beta.kubernetes.io/zone"
labelSelector:
matchLabels:
job-name: job-{{ id }}
crawl: {{ id }}
tolerations:
- key: "nodeType"
operator: "Equal"
value: "crawling"
effect: "NoSchedule"
containers:
- name: redis
image: {{ redis_image }}
imagePullPolicy: {{ redis_image_pull_policy }}
args: ["/redis-conf/redis.conf", "--appendonly", "yes"]
volumeMounts:
- name: redis-data
mountPath: /data
- name: shared-redis-conf
mountPath: /redis-conf
resources:
limits:
memory: {{ redis_memory }}
requests:
cpu: {{ redis_cpu }}
memory: {{ redis_memory }}
readinessProbe:
exec:
command:
- redis-cli
- ping
---
apiVersion: v1
kind: Service
metadata:
name: redis-{{ id }}
labels:
crawl: {{ id }}
role: redis
spec:
clusterIP: None
selector:
crawl: {{ id }}
role: redis
ports:
- protocol: TCP
port: 6379
name: redis