参考文档链接:https://juejin.cn/post/7284885060339679251
helm repo add bitnami https://charts.bitnami.com/bitnami
helm search repo redis
helm fetch bitnami/redis
tar -xf redis-18.6.1.tgz
cd redis/
cp values.yaml values.yaml.bak
vim values.yaml
global:
...
...
# 配置sc
storageClass: "nfs-client"
# redis的密码
redis:
password: "pass_123456"
...
...
# 开启哨兵模式
sentinel:
enabled: true
helm install redis . -f values.yaml
# 获取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集群主节点的信息
redis集群从节点的信息
查看哨兵信息
查看redis的svc
将redis的svc通过nodeport的方式暴露出来,然后通过node_ip:nodeport
的方式访问redis即可
kubectl edit svc redis
...
...
type: NodePort #由LoadBalancer改为NodePort
...
...