论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
ToB企服应用市场:ToB评测及商务社交产业平台
»
论坛
›
软件与程序人生
›
DevOps与敏捷开发
›
Redis分布式办理方案 codis
Redis分布式办理方案 codis
半亩花草
金牌会员
|
2024-7-13 09:03:21
|
显示全部楼层
|
阅读模式
楼主
主题
775
|
帖子
775
|
积分
2325
引言
在大数据高并发场景下,单个Redis实例往往会显得捉襟见肘。首先体如今内存上,单个Redis的内存不宜过大,内存太大会导致rdb文件过大,进一步导致主从同步时全量同步时间过长,在实例重启恢复时也会消耗很长的时间加载数据。其次,体如今CPU利用率上,单个Redis实例只能利用单个核心,单个核心要完成海量数据的存取和管理工作压力会很大。
正是在这样的大数据高并发需求之下,Redis集群方案应运而生。他可以将多个众多小内存的Redis实例综合起来,将分布在多台呆板上的众多CPU核心的计算本领聚集到一起,完成海量数据存储和高并发读写操作。
Codis上挂接的 所有Redis实例构成一个Redis集群,当集群空间不足时,可以通过动态增长Redis实例来实现扩容需求。
客户端操作Codis同操作Redis险些没有区别,还是可以使用类似的客户端SDK,不须要任何变化。
因为Codis是无状态的,他只是一个转发署理中心件,意味着我们可以启动多个Codis实例,供客户端使用,每个Codis节点都是对等的。因为单个Codis署理能支撑的QPS比力有限,通过启动多个Codis署理可以显著增长整体的QPS需求,还能起到容灾功能。
分片原理
Codis要负责将特定的key转发到特定的Redis实例,
Codis将所有的key默认分别为1024个槽位(slot),他首先将客户端传来的key进行crc32运算计算哈希值,再将hash后的整数值对1024这个整数进行取模得到一个余数,这个余数就是对应key的槽位,每个槽位都会唯一映射到后面的多个Redis实例之一,Codis会在内存维护槽位和Redis实例的映射关系。
。
差别的Codis实例之间槽位关系怎样同步
如果Codis的槽位映射关系只存储在内存里,那么差别的Codis实例之间的槽位关系就无法得到同步。以是,Codis须要一个分布式设置存储数据库专门用来恒久化槽位关系。
Codis将槽位关系存储在zk中,而且提供了一个Dashboard可以用来观察和修改槽位关系,当槽位关系变化时,Codis Proxy会监听到变化并重新同步槽位关系。从而实现多个Codis Proxy之间共享类似的槽位关系设置。
扩容
刚开始Codis后端只有一个Redis实例,1024个槽位全部指向同一个Redis。然后一个Redis实例内存不敷了,以是又加了一个Redis实例,这时候须要对槽位关系进行调整,将一半的槽位分别到新的节点。这意味着须要对这一半的槽位对应的所有key进行迁移,迁移到新的Redis实例。
Codis对Redis进行了改造,增长了slotsscan指令,可以遍历指定slot下所有的key。然后迁移每个key到新的Redis节点。
在迁移过程中,Codis还是会吸收到新的哀求落在当前正在迁移的槽位上,因为当前槽位的数据同时存在于新旧两个槽位中,Codis无法判断迁移过程中的key究竟在哪个实例中,以是采用了另一种完全差别的思路。当
Codis吸收到位于正在迁移槽位中的key后,会立刻逼迫对当前的单个key进行迁移,迁移完成后,再将哀求转发到新的Redis实例
。
Codis的代价
Codis给Redis带来了扩容的同时,也损失了一些其他特性。因为Codis中所有的key分散在差别的Redis实例中,以是变乱就不再支持。变乱只能在单个Redis实例中完成。
同时,为了支持扩容,单个key对应的value不宜过大,因为集群的最小迁移单位是key。对于一个hash结构,他会一次性使用hgetall拉取所有内容,然后使用hmset放置到另一个节点。如果hash内部的kv太多,容易带来迁移卡顿。
Codis因为增长了Proxy作为中转层,以是在网络开销上要比Redis 大,整体性能上比单个Redis性能有所下降。
Codis集群设置中心使用zk来实现,在部署上增长了zk运维的代价。
Mget指令的操作过程
mget指令用于批量获取多个key的值,这些key 大概会分布在多个Redis实例中。Codis的策略是将key按照所分配的实例打散分组,然后依次对每个实例调用mget方法,最后将结果进行汇总,返回给客户端。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
回复
使用道具
举报
0 个回复
倒序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
发新帖
回复
半亩花草
金牌会员
这个人很懒什么都没写!
楼主热帖
本周涨粉一倍,我决定再开源一个商超管 ...
YOLOV5 代码复现以及搭载服务器运行 ...
安装Python
【Redis】BigKey问题
经典Python题目:一个列表或者数组去重 ...
《C++性能优化指南》 linux版代码及原 ...
go-zero插件goctl-swagger的坑
Spring简介-IOC
Java集合框架(五)-Collections 和 泛型 ...
Spring Boot 宣布移除 run 命令,真让 ...
标签云
挺好的
服务器
快速回复
返回顶部
返回列表