helm部署redis高可用集群

文章目录

    • 1. 添加helm源
    • 2. 下载最新版的redis的charts
    • 3. 解压并备份values文件
    • 4. 修改values文件
    • 5. 部署到k8s集群中
    • 6. 验证
    • 7. 模拟冗灾
    • 8. 使用

1. 添加helm源

helm repo add bitnami https://charts.bitnami.com/bitnami

2. 下载最新版的redis的charts

helm search repo redis
helm fetch bitnami/redis

3. 解压并备份values文件

tar -xf redis-18.6.1.tgz
cd redis/
cp  values.yaml  values.yaml.bak

4. 修改values文件

vim values.yaml

global:
  ...
  ...
  # 配置sc
  storageClass: "nfs-client"
  # redis的密码
  redis:
    password: "pass_123456"
...
...
# 开启哨兵模式
sentinel:
  enabled: true
  quorum: 3

5. 部署到k8s集群中

helm install redis . -f values.yaml

helm部署redis高可用集群_第1张图片

6. 验证

# 获取redis的密码
export REDIS_PASSWORD=$(kubectl get secret --namespace default redis -o jsonpath="{.data.redis-password}" | base64 -d)
# 运行redis-client容器
kubectl run --namespace default redis-client --restart='Never'  --env REDIS_PASSWORD=$REDIS_PASSWORD  --image docker.io/bitnami/redis:7.2.3-debian-11-r2 --command -- sleep infinity
# 进入redis-client容器
kubectl exec --tty -i redis-client \
   --namespace default -- bash
# 在redis-cli容器中使用redis-cli命令连接集群
REDISCLI_AUTH="$REDIS_PASSWORD" redis-cli -h redis -p 6379 # Read only operations
REDISCLI_AUTH="$REDIS_PASSWORD" redis-cli -h redis -p 26379 # Sentinel access

# 暴露redis的端口,使外部的服务可以访问redis集群
kubectl port-forward --namespace default svc/redis 6379:6379 & REDISCLI_AUTH="$REDIS_PASSWORD" redis-cli -h 127.0.0.1 -p 6379

redis集群信息,可以发现node-1是主节点

kubectl exec -it redis-node-0 -- redis-cli -h redis -a $(kubectl get secret redis -o jsonpath="{.data.redis-password}" | base64 -d) info replication
kubectl exec -it redis-node-1 -- redis-cli -h redis -a $(kubectl get secret redis -o jsonpath="{.data.redis-password}" | base64 -d) info replication
kubectl exec -it redis-node-2 -- redis-cli -h redis -a $(kubectl get secret redis -o jsonpath="{.data.redis-password}" | base64 -d) info replication



查看哨兵信息
helm部署redis高可用集群_第2张图片

7. 模拟冗灾

kill掉node-1的pod,可以看到master已经到了node-2中

kubectl delete pod redis-node-1

8. 使用

查看redis的svc
在这里插入图片描述
将redis的svc通过nodeport的方式暴露出来,然后通过node_ip:nodeport的方式访问redis即可
kubectl edit svc redis

...
...
type: NodePort #由LoadBalancer改为NodePort
...
...

helm部署redis高可用集群_第3张图片

你可能感兴趣的:(k8s,工具,redis,缓存)