基于Codis的Redis集群部署

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: Codis是基于代理的高性能Redis集群方案,使用Go语言进行开发,现在在在豌豆荚及其它公司内已经广泛使用,当然也包括我们公司。Codis与常见的Redis集群方案对比。

Codis是基于代理的高性能Redis集群方案,使用Go语言进行开发,现在在在豌豆荚及其它公司内已经广泛使用,当然也包括我们公司。

Codis与常见的Redis集群方案对比。


img_7ee8b990ffc15737528a318fde529212.png
image.png

在搭建的时候,个人觉得Redis Cluster搭建起来非常容易,但是redis-cluster没有GUI管理面板,另外查询资料发现redis-cluster的客户端实现redis-cluster的协议比较麻烦。

而codis在使用的时候,就像正常连接redis客户端一样,不过codis有些命令不支持。动手吧

多看几眼这个官方架构图,有助于我们理解codis的架构,方便后面操作


img_f3e296b18d30b5884cefdf21fa6c7cd3.png
image.png

过程

  1. 如果编译安装codis,安装codis依赖的库,使用yum安装的golang库默认在/usr/lib/golang目录下,编译起来也没有很麻烦了
yum install golang -y
yum install autoconf -y
  1. 下载源文件,并且编译
cd /usr/lib/golang
mkdir -p src/github.com/CodisLabs
cd src/github.com/CodisLabs/
git clone https://github.com/CodisLabs/codis.git -b release3.2
cd codis
make

然后会得到编译的文件,不出意外都可以编译成功,记得安装linux的开发工具包

img_a8ca42c967c7af18c8077ac89e293812.png
image.png
  1. 在运行命令之前,先看一下运行命令包含的内容
    在config目录下,会有运行几个组件的配置文件,这些文件都可以使用命令自动生成
codis-dashboard  --default-config #生成codis-dashboard的默认配置文件
codis-proxy --default-config  #生成codis-proxy的默认配置文件

如果你对zookeeper,etcd等分布式协调组件比较熟悉,这两个命令生成的配置文件中都可以指定使用zookeeper,或者etcd, jodis是基于codis的redis客户端。


img_edcb2999372b80dd7189cf52a217c174.png
image.png
img_cd182186f181770e3198c9de7842427d.png
image.png

相关的shell脚本,看一下admin目录中的内容,都可以理解的,修改下配置文件什么的

  1. 运行集群
./admin/codis-proxy-admin.sh start  #dashboard提供REST API管理codis的集群
./admin/codis-proxy-admin.sh start  #codis代理,使用的时候连接的是codis-proxy
./admin/codis-fe-admin.sh start     #fe,用来提供GUI管理codis的

到这一步的时候,我们已经可以访问codis的管理界面了,访问http://127.0.0.1:9090,这个时候codis的管理面板基本上是空的。

  1. 运行redis服务器,就像常规的运行redis服务器,可以设置slave等相关
./redis-server /etc/redis/redis_6379.conf   # 记得设置redis绑定地址或者认证相关
./redis-server /etc/redis/redis_6380.conf   #这个设置为6379的slave

设置为redis的slave,指定slaveof 127.0.0.1:6379。

  1. 在codis-fe的管理面板中操作
    首先添加codis-proxy


    img_245b80cf39be921a9f2b375b0a5f6a48.png
    image.png

然后添加redis-group,可以添加不同的group,然后往group里面添加服务器,留意Data CenterGroup,正常情况下在每一个组中添加的第一台服务器都是master,往后都是slave,就算你添加的是另外的master节点,点击绿色的修复按钮,新加入的master也会变成slave的。

img_249c9496ac73ec5609254784e2975050.png
image.png

  1. 测试,留意上面的图片,我添加了两台codis-proxy,然后4台redis-server,我们可以做测试了。
img_317d305817c2fd31bdc4e159fa5f9ca8.png
image.png
  1. 连接到不同的codis-proxy上面取得的数据都是一样的,这样当我们配置多个proxy的时候,其中的proxy挂掉了,也是可以正常使用的,另外通过管理界面,我们可以动态的添加redis-server。

注意点

集群搭建起来,参考官方的文档也不会很麻烦,完成一整套流程之后,提醒一些搭建的时候要注意的点。

  1. 管理面板上的,在管理codis-proxy那一部分,可以看到我们的命令执行情况,命令分配到那一台主机。
  2. 加入新的redis-server之后,不要忘记了迁移slot,如果再生产环境迁移slot要注意时机。
  3. redis-proxy可以配置不同的data-center,我想这个在客户端使用工具的时候可以指定。

配置多个proxy,连接不同的proxy获取的数据都是一致的,proxy代理的是多个redis-master,数据在后端的redis-server上也是分片存储的。

如果配置了多个redis-master,也可以说redis-group,每一个master存储的是部分的数据。

最后

纸上得来终觉浅,在公司内部一般有专门的运维来负责这部分的维护,保证高可用相关内容。另外真正搭建过cods之后,觉得codis比redis-cluster好用一些,除了搭建复杂一点,概念多了一点点,后续使用很简单了。

参考

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
5月前
|
Kubernetes NoSQL Redis
k8s快速部署Redis单机
k8s快速部署Redis单机
|
24天前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
115 26
|
2月前
|
监控 NoSQL 网络协议
【Azure Redis】部署在AKS中的应用,连接Redis高频率出现timeout问题
查看Redis状态,没有任何异常,服务没有更新,Service Load, CPU, Memory, Connect等指标均正常。在排除Redis端问题后,转向了AKS中。 开始调查AKS的网络状态。最终发现每次Redis客户端出现超时问题时,几乎都对应了AKS NAT Gateway的更新事件,而Redis服务端没有任何异常。因此,超时问题很可能是由于NAT Gateway更新事件导致TCP连接被重置。
|
7月前
|
存储 运维 NoSQL
Redis Cluster集群模式部署
Redis Cluster集群模式部署
133 4
|
7月前
|
缓存 运维 NoSQL
Redis主从模式部署
Redis主从模式部署
70 4
|
7月前
|
运维 监控 NoSQL
Redis Sentinel哨兵模式部署
Redis Sentinel哨兵模式部署
123 2
|
8月前
|
存储 监控 负载均衡
保证Redis的高可用性是一个涉及多个层面的任务,主要包括数据持久化、复制与故障转移、集群化部署等方面
【5月更文挑战第15天】保证Redis高可用性涉及数据持久化、复制与故障转移、集群化及优化策略。RDB和AOF是数据持久化方法,哨兵模式确保故障自动恢复。Redis Cluster实现分布式部署,提高负载均衡和容错性。其他措施包括身份认证、多线程、数据压缩和监控报警,以增强安全性和稳定性。通过综合配置与监控,可确保Redis服务的高效、可靠运行。
242 2
|
3月前
|
NoSQL Linux Shell
Redis 的安装与部署(图文)
Redis 的安装与部署(图文)
|
4月前
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
|
5月前
|
Kubernetes NoSQL Redis
【Azure Redis】部署在AKS中的应用连接Redis时候出现Unable to connect to Redis server
【Azure Redis】部署在AKS中的应用连接Redis时候出现Unable to connect to Redis server
【Azure Redis】部署在AKS中的应用连接Redis时候出现Unable to connect to Redis server