redis集群主流架构方案分析.doc_第1页
redis集群主流架构方案分析.doc_第2页
redis集群主流架构方案分析.doc_第3页
redis集群主流架构方案分析.doc_第4页
redis集群主流架构方案分析.doc_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

redis集群主流架构方案分析 Redis在互联网大数据平台有着广泛的应用,主要被用来缓存热点数据,避免海量请求压垮数据库,同时可以提升服务节点的响应速度和并发量。随着数据量的增多,由于redis是占用单台物理机或虚机的内存,内存资源是有限的,要动态地扩容缩容,就需要用到redis集群。redis集群的架构方案经历了一系列演变和改良的过程,本文介绍了四种主流的redis架构方案。客户端分片优点不使用第三方中间件,实现方法和代码可以自己掌控并且可随时调整。这种分片性能比代理式更好(因为少了分发环节),分发压力在客户端,无服务端压力增加缺点不能平滑地水平扩容,扩容/缩容时,必须手动调整分片程序,出现故障不能自动转移,难以运维Twemproxy优点运维成本低。业务方不用关心后端 Redis 实例,跟操作 Redis 一样。Proxy 的逻辑和存储的逻辑是隔离的缺点a. 代理层多了一次转发,性能有所损耗b. 进行扩容/缩容时候,部分数据可能会失效,需要手动进行迁移,对运维要求较高,而且难以做到平滑的扩缩容c. 出现故障,不能自动转移,运维性很差Redis Cluster优点a. 无中心节点b. 数据按照 Slot 存储分布在多个 Redis 实例上c. 平滑的进行扩容/缩容节点d. 自动故障转移(节点之间通过 Gossip 协议交换状态信息,进行投票机制完成 Slave 到 Master 角色的提升)e. 降低运维成本,提高了系统的可扩展性和高可用性缺点a. 严重依赖外部 Redis-Tribb. 缺乏监控管理c. 需要依赖 Smart Client(连接维护, 缓存路由表, MultiOp 和 Pipeline 支持)d. Failover 节点的检测过慢,不如“中心节点 ZooKeeper”及时e. Gossip 消息的开销f. 无法根据统计区分冷热数据g. Slave“冷备”,不能缓解读压力Proxy Redis Cluster优点Smart Client:a. 相比于使用代理,减少了一层网络传输的消耗,效率较高。b. 不依赖于第三方中间件,实现方法和代码自己掌控,可随时调整。Proxy:a. 提供一套 HTTP Restful 接口,隔离底层存储。对客户端完全透明,跨语言调用。b. 升级维护较为容易,维护 Redis Cluster,只需要平滑升级 Proxy。c. 层次化存储,底层存储做冷热异构存储。d. 权限控制,Proxy 可以通过秘钥控制白名单,把一些不合法的请求都过滤掉。并且也可以控制用户请求的超大 Value 进行控制,和过滤。e. 安全性,可以屏蔽掉一些危险命令,比如 Keys、Save、Flush All 等。f. 容量控制,根据不同用户容量申请进行容量限制。g. 资源逻辑隔离,根据不同用户的 Key 加上前缀,来进行资源隔离。h. 监控埋点,对于不同的接口进行埋点监控等信息。缺点Smart Client:a. 客户端的不成熟,影响应用的稳定性,提高开发难度。b. MultiOp 和 Pipeline 支持有限。c. 连接维护,Smart 客户端对连接到集群中每个结点 Socket 的维护。Proxy:a. 代理层多了一次转发,性能有所损耗。b进行扩容/缩容时候对运维要求较高,而且难以做到平滑的扩缩容实际项目中该如何选型呢?redis官方文档中有如下这段话:The redis-cli cluster support is very basic so it always uses the fact that Redis Cluster nodes are able to redirect a client to the right node. A serious client is able to do better than that, and cache the map between hash slots and nodes addresses, todirectly use the right connection to the right node. The map is refreshed only when something changed in the cluster configuration, for example after a failover or after the system administrator changed the cluster layout by adding or removing nodes.大意就是目前redis cluster官方客户端功能简陋,依赖于redis节点重定向去到集群中找到数据所在的redis实例。需要有一个更完善的客户端,能够实现一致性hash,failover和集群管理功能。因此使用官方的redis cluster客户端不是一个明智的选择,本文提供3种方案供大家参考,如果有不合理的地方,欢迎大家与我共同探讨。方案 1 使用nginx开发(OpenResty方式)原因如下a. 单 Master 多 Work 模式,每个 Work 跟 Redis 一样都是单进程单线程模式,并且都是基于 Epoll 事件驱动的模式。b. Nginx 采用了异步非阻塞的方式来处理请求,高效的异步框架。c. 内存占用少,有自己的一套内存池管理方式,。将大量小内存的申请聚集到一块,能够比Malloc 更快。减少内存碎片,防止内存泄漏。减少内存管理复杂度。d. 为了提高 Nginx 的访问速度,Nginx 使用了自己的一套连接池。e. 最重要的是支持自定义模块开发。f. 业界内,对于 Nginx,Redis 的口碑可称得上两大神器。性能也就不用说了。方案 2 codis (豌豆荚采用的基于代理的redis集群方案)参考codis官方文档/CodisLabs/codisCodis是一整套缓存解决方案,包含高可用、数据分片、监控、动态扩态 etc.。走的是 Apps-代理-redis cluster,一定规模后基本都采用这种方式。

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论