Redis集群实现方案

http://redis.io/topics/partitioning

分片




我经历的项目中把redis仅仅当做内存缓存、没有开启持久化

为什么用集群?

高可用、高性能、高可扩展

高可用如何实现?

冗余存储(保证不丢失)+主备切换

分片(即使节点挂了也是之丢失部分数据)

高性能如何实现?

分片(降低单节点的负载)

高可扩展如何实现?

分片(加机器)



1:客户端分布式

memcache可以这么做

一致性hash

多个redis server相互独立

缺点:增删机器需要修改客户端设置、数据丢失


2:通过代理

Twemproxy

Codis

缺点:多了一层有性能损失

呵呵,关于 Twemproxy和Codis的比较,可以看看Codis文档

https://github.com/CodisLabs/codis

当然,有些命令和功能,并不支持


3:Redis cluster

没有中心节点、Redis Cluster将所有Key映射到16384个Slot中,集群中每个Redis实例负责一部分,业务程序通过集成的Redis Cluster客户端进行操作

客户端可以向任一实例发出请求,如果所需数据不在该实例中,则该实例引导客户端自动去对应实例读写数据。Redis Cluster的成员管理(节点名称、IP、端口、状态、角色)等,都通过节点之间两两通讯,定期交换并更新

能做分片?能冗余数据?能故障自动切换?

Redis Sentinel:

复制+Sentinel集群

多个Sentinel节点(Sentinel集群)监视多个主服务器以及每个主服务器的从节点。

主服务器下线之后(如何判断下线?每个sentinel节点可能观察到的不一样。可以配置一个策略比如超过几个sentinel节点判断主节点下线那就认为主节点确实已经下线),sentinel集群会选举(如何选举呢?)一个从节点变为主节点并进行一些各个节点状态数据的设置(具体的操作是由sentinel集群中选举出来的领头sentinel节点)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本文档翻译自 http://redis.io/topics/cluster-tutorial 。 本文档是 Red...
    会跳舞的机器人阅读 66,985评论 2 21
  • Codis 3.2 部署配置汇总 概念总结 集群配置前需要了解架构,集群分片主要分三种: 客户端分片:这个需要自己...
    三杯水Plus阅读 6,072评论 0 11
  • 本文针对Redis以及redis的几种集群方案的调研日期在2016年8月,后续如果各框架有更新与本文不符,请自行甄...
    范安林阅读 76,362评论 0 35
  • 本文将从Redis的基本特性入手,通过讲述Redis的数据结构和主要命令对Redis的基本能力进行直观介绍。之后概...
    kelgon阅读 61,290评论 23 625
  • Redis集群方案 通常,为了提高网站响应速度,总是把热点数据保存在内存中而不是直接从后端数据库中读取。Redis...
    jiangmo阅读 618评论 0 3