前言
Redis 是在开发过程中经常用到的缓存中间件,为了考虑在生产环境中稳定性和高可用,Redis通常采用集群模式的部署方式。
在制定Redis集群的部署策略时,常规部署在虚拟机上的方式配置繁琐并且需要手动重启节点,相较之下,使用 PetaExpress 提供的
Kubernetes(k8s) 服务 进行 Redis 集群的部署,则展现出了显著的优势:
1、安装便捷:使用镜像或者 yaml 配置文件即可一件安装,极大地简化了安装流程
2、缩扩容方便:在 扩容 、 缩容 方面的优点一键伸缩,无需复杂的配置和繁琐的步骤
3、智能自动调度:容器意外挂掉后能够迅速进行自动调度重启和资源分配
4、高效且稳定: Kubernetes 在整个集群上进行调度,只要整个集群不挂掉总会调度到合适节点重启容器服务
阅读全文,后面告诉你怎么免费白拿红包
在 PetaExpress KubeSphere容器平台部署 Kubernetes集群
在 Peta Express 中部署 Kubernetes 非常简单,直接使用 Peta Express 中内置的 QKE 即可,登录到 Peta Express 控制台,在产品与服务中找到 AppCenter 控制台 → 应用中心。
根据集群的规模,部署时间大致2分钟到10分钟不等,还是非常快的。部署完 Kubernetes, 接下来我们就可以开始进入正题 安装 Redis 了。
安装 Redis 集群
我这里新建了一个 test-project 的项目空间来做 Redis 集群所有安装资源的放置,后续在 DNS 上会用到项目空间名称,会标注这一部分,需要注意用自己的项目空间名。
Redis 集群的安装流程大致分为以下几个关键步骤:
①配置 redis.conf 字典;
②创建 redis 服务;
③容器组配置;
④存储设置;
⑤高级设置。
接下来,我们将从第一步开始,逐步完成 Redis 集群的安装和配置过程。
配置 redis.conf 字典
key 值的内容为 redis.conf , value 值为:
创建 Redis 服务
基本设置里名称就叫 redis-cluster 然后进行重头戏,下一步的 容器组配置 。
容器组配置
镜像选择 docker hub 中 redis ,并选择使用默认端口,CPU和内存可以选择性预留,如果不预留就是调度公共资源。
选择 使用默认端口 的话下面的端口设置就是如上图一样都会使用 6379 ,还有就是配置启动命令。
如上图配置:
命令: redis-server
参数: /etc/redis/redis.conf
在这一步有两个操作
添加存储卷模板
添加存储卷模板
PVC 名称前缀:redis-pvc
容量:10G
挂载路径:
权限:读写
地址:/data
挂载配置字典或保密字典
高级设置 里是一些额外配置,可以根据自己场景选择调整配置,调成完成后点击 创建 进行 Redis 集群容器的创建。
初始化 Redis 集群
按上图示例 比如访问集群 1 节点访问地址就是 redis-cluster-v1-1 加 DNS 地址 redis-cluster.test-project 加svc.cluster.local ,完整地址如下:
1
redis-cluster-v1-
1
.redis-cluster.test-project.svc.cluster.local
2
在 redis 集群的非第一节点的其他节点终端内通过这个地址进行访问验证他们是否互通,进入 3 节点的终端,如下图:
进入终端,执行命令:
如果能如下图一样跳转到 v1-1 的节点上就代表这两个节点互通。
1 redis-cli -h redis-cluster-v1-1.redis-cluster.test-project.svc.clusterredis.local
2
主要看上图的这两个参数, nodes 为 1 表明当前节点只有 1 个, cluster_size 表明当前没有 master 节点,所以目前还不是集群结构, info 属性的详解在此列出:
cluster_state :ok 状态表示集群可以正常接受查询请求。fail 状态表示,至少有一个哈希槽没有被绑定(说明有哈希槽没有被绑定到
任意一个节点),或者在错误的状态(节点可以提供服务但是带有 FAIL 标记),或者该节点无法联系到多数 master 节点。
cluster_slots_assigned :已分配到集群节点的哈希槽数量(不是没有被绑定的数量)。16384 个哈希槽全部被分配到集群节点是集群
正常运行的必要条件。
cluster_slots_ok :哈希槽状态不是 FAIL 和 PFAIL 的数量。
cluster_known_nodes :集群中节点数量,包括处于握手状态还没有成为集群正式成员的节点。
cluster_slots_pfail :哈希槽状态是 PFAIL 的数量。只要哈希槽状态没有被升级到 FAIL 状态,这些哈希槽仍然可以被正常处理。
PFAIL 状态表示我们当前不能和节点进行交互,但这种状态只是临时的错误状态。
cluster_slots_fail : 哈希槽状态是 FAIL 的数量。如果值不是 0,那么集群节点将无法提供查询服务,除非 cluster-require-full
coverage 被设置为 no。
cluster_current_epoch :集群本地 Current Epoch 变量的值。这个值在节点故障转移过程时有用,它总是递增和唯一的。
cluster_my_epoch :当前正在使用的节点的 Config Epoch 值。这个是关联在本节点的版本值。
cluster_size :至少包含一个哈希槽且能够提供服务的 master 节点数量。
cluster_stats_messages_sent :通过 node-to-node 二进制总线发送的消息数量。
cluster_stats_messages_received :通过 node-to-node 二进制总线接收的消息数量。
IP 地址初始化集群(初始化方案一)
先尝试使用 ip + port 的方式初始化集群,但是在 Kubernetes( K8s) 中启动服务 ip 都会变化,所以最终的结果还是要用 DNS 方式进行集群初始化。
执行本步后再想修改为 DNS 地址初始化需要从来一遍,如果不想麻烦的同学可以直接跳过。
1redis-cli --cluster create 10.233.70.30:6379 10.233.70.32:6379 10.233.90.41:6379 10.233.90.43:6379 10.233.96.47:6
2
现在我们的集群节点有了 6 个, master 节点也有了三个,集群建立完成,后面的操作选择 master 节点进行操作。
在对集群节点进行验证的时候如果遇到上图的错误 (error) MOVED 2589 10.233.70.30:6379 是因为 redis-cli 没有开启集群模式,将命令修改为 redis-cli -c 就切换为集群模式了。
使用内部 DNS 初始化(初始化方案二)
使用 ip 地址的方式在每次 K8s 调度 redis 后 ip 都会发生变化,所以在 K8s 集群中使用 ip 方式初始化集群并不太合适,但是如果使用内部 DNS 直接跟上面一样初始化集群会出现错误,因为 redis 对域名的支持并不太好,所以这时候可以用 Redis-tribe 。
创建 Redis-tribe 服务
参数
namespace
就写项目名称:
具体 YAML 内容如下:
创建好后在容器组内找到 redis-cluster-tools 。
初始化集群
点击容器名称进入容器详情再进入到终端里。
1apiVersion: apps/v1
2kind: Deployment
3metadata:
4namespace: test-project
5labels:
6app: redis-cluster-tools
7name: redis-cluster-tools
8spec:
9replicas: 1
10selector:
11matchLabels:
12app: redis-cluster-tools
13template:
14metadata:
15labels:
16app: redis-cluster-tools
17name: pos-redis
18spec:
19containers:
20- name: pos-redis
21image: sunnywang/redis-tools-ubuntu:v0.5.1
22imagePullPolicy: IfNotPresent
23args:
24- /bin/bash
25- -c
26- sleep 3600
27
初始化集群
先执行以下命令初始化 master 节点,这时候之前的内部 DNS 的域名就有用了。
1 redis-trib.py create dig +short redis-cluster-v1-0.redis-cluster.test-project.svc.cluster.local:6379 `dig +shor
2
接下来给每个 master 节点绑定对应的副本节点,总共三个:
0 节点->3 节点
1redis-trib.py create dig +short redis-cluster-v1-0.redis-cluster.test-project.svc.cluster.local:6379 `dig +shor
2
1 节点->4 节点
1redis-trib.py replicate --master-addr `dig +short redis-cluster-v1-0.redis-cluster.test-project.svc.cluster.local
2
2 节点->5 节点
1redis-trib.py replicate --master-addr `dig +short redis-cluster-v1-1.redis-cluster.test-project.svc.cluster.loca
2
验证
验证集群模式可以正常使用。
到此这篇redis集群客户端连接ip配置(redis-cli集群连接)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!版权声明:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权、违法违规、事实不符,请将相关资料发送至xkadmin@xkablog.com进行投诉反馈,一经查实,立即处理!
转载请注明出处,原文链接:https://www.xkablog.com/hd-yjs/41565.html