我记得我们之前讨论过这个话题here https://stackoverflow.com/questions/70257094/redis-master-slave-on-gcp-memorystore,不用担心在这里添加更多。
阅读有关 Redis helm 图表的更多信息:https://github.com/bitnami/charts/tree/master/bitnami/redis#choose- Between-redis-helm-chart-and-redis-cluster-helm-chart https://github.com/bitnami/charts/tree/master/bitnami/redis#choose-between-redis-helm-chart-and-redis-cluster-helm-chart
您还应该问我的申请将如何进行的问题
连接到同一个Node上的POD,而不使用Redis的服务。
为此,您可以使用`环境变量并将它们公开给应用 POD.
就像是 :
env:
- name: HOST_IP
valueFrom:
fieldRef:
fieldPath: status.hostIP
它会给你带来的价值Node IP其上的POD正在运行,然后您可以使用该 IP 来连接守护进程集(Redis 从机,如果您正在运行)。
您可以阅读更多内容:https://kubernetes.io/docs/tasks/inject-data-application/environment-variable-expose-pod-information/ https://kubernetes.io/docs/tasks/inject-data-application/environment-variable-expose-pod-information/
是否可以自动化此类部署(例如使用 Helm)?
是的,您可以写下自己的Helm图表并部署生成的YAML显现。
最重要的是,这个架构对于我想要的东西来说是一个好主意吗?
做?有没有其他方法可以达到同样快的速度?
如果您认为这是一个好主意,根据我的考虑,这可能会创造$$$问题和更高的集群资源使用率。
如果您在 200 个节点上运行 Redis 从属节点会怎样?这可能会消耗每个节点上的资源并增加您的成本infra.
OR
如果您正在计划具体部署
您的上述建议也很好,但是,如果您打算使用Redis with 仅具体 部署您还可以使用 sidecar 模式并使用配置将多个 Redis 连接在一起。
apiVersion: v1
kind: Service
metadata:
name: web
labels:
app: web
spec:
ports:
- port: 80
name: redis
targetPort: 5000
selector:
app: web
type: LoadBalancer
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: web
spec:
selector:
matchLabels:
app: web
replicas: 3
template:
metadata:
labels:
app: web
spec:
containers:
- name: redis
image: redis
ports:
- containerPort: 6379
name: redis
protocol: TCP
- name: web-app
image: web-app
env:
- name: "REDIS_HOST"
value: "localhost"