在Kubernetes上部署Redis,你可以选择部署单机版Redis或者Redis集群。以下是使用Deployment和Service资源对象的基本YAML配置示例。
单机Redis部署
创建名为 redis-deployment.yaml
的文件,内容如下:
apiVersion: apps/v1
kind: Deployment
metadata:
name: redis-deployment
spec:
selector:
matchLabels:
app: redis
replicas: 1
template:
metadata:
labels:
app: redis
spec:
containers:
- name: redis
image: "redis:alpine"
ports:
- containerPort: 6379
然后创建名为 redis-service.yaml
的文件,内容如下:
apiVersion: v1
kind: Service
metadata:
name: redis-service
spec:
selector:
app: redis
ports:
- protocol: TCP
port: 6379
targetPort: 6379
使用以下命令部署到Kubernetes集群:
kubectl apply -f redis-deployment.yaml
kubectl apply -f redis-service.yaml
Redis集群部署
Redis集群部署通常需要使用外部的Redis实现,例如Bitnami的Redis Operator或Redis Enterprise。这里我们使用Bitnami Redis Operator来演示。
首先,安装Bitnami Redis Operator:
kubectl apply -f https://raw.githubusercontent.com/bitnami/redis-operator/master/bundle/manifests/redis-operator-controller-deployment.yaml
然后,创建一个Redis集群的定义,例如 redis-cluster.yaml
:
apiVersion: redis.bnc.io/v1
kind: RedisCluster
metadata:
name: redis-cluster
spec:
replicas: 3
podTemplate:
spec:
containers:
- name: redis
resources:
requests:
memory: "500Mi"
cpu: "500m"
使用以下命令部署Redis集群:
kubectl apply -f redis-cluster.yaml
请注意,这些示例提供了基本的部署配置。根据你的实际需求,你可能需要调整资源配置、持久化存储、网络策略、安全设置等。