容器名:redis-1, redis-2, redis-3, redis-4, redis-5, redis-6 监听端口:6379, 6380, 6381, 6382, 6383, 6384 请在命令行编写YAML文件,部署Redis集群。
时间: 2024-11-26 19:06:18 浏览: 19
在Kubernetes中,为了部署一个具有多个容器实例并映射特定端口的Redis集群,我们需要创建一个Deployment和Service。以下是一个简单的示例YAML文件,它将部署6个Redis节点,每个节点监听一个不同的端口号:
```yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: redis-cluster
spec:
replicas: 6
selector:
matchLabels:
app: redis
template:
metadata:
labels:
app: redis
spec:
containers:
- name: redis
image: redis:alpine
ports:
- containerPort: {{ .Ordinal }}
protocol: TCP
env:
- name: REDIS_PORT
value: "{{ .Ordinal }}"
command: ["redis-server", "--port", "$(REDIS_PORT)", "--protected-mode", "no"]
---
apiVersion: v1
kind: Service
metadata:
name: redis-cluster
spec:
type: LoadBalancer
selector:
app: redis
ports:
- name: main
port: 6379
targetPort: {{ range $i, $_ := . }}{{$i}}{{ end }}
protocol: TCP
```
在这个YAML中,`.Ordinal`会返回当前容器的索引,从0开始,所以我们需要在实际环境中替换这些模板变量。例如,如果我们要部署到5个容器,那么`{{ .Ordinal }}`将分别变为`0`, `1`, `2`, `3`, 和 `4`,对应于给定的端口号范围。
注意,`LoadBalancer`类型的Service在某些环境(如AWS或Google Cloud Platform)可以分配一个外部IP地址,提供对外公开的访问。如果是其他环境,可能需要调整Service类型。
阅读全文