Redis集群学习笔记

前言

最近有个需求,就是将一个Redis集群中数据转移到某个单机Redis上。

迁移Redis数据的话,如果是单机Redis,有两种方式:
a. 执行redis-cli shutdown命令,触发写RDBAOF写磁盘操作,然后将RDB文件和AOF文件都拷贝到新服务器上,然后运行服务器即可。
b. 如果不想暂停服务,可以用工具,比如Redis Dump;也可以采用Redis提供的Master Slave方式同步数据。

但是,如果是Redis集群的话,每个Redis实例上面只有部份数据,这就不太好办了。因此,有必要学习Redis集群的相关知识。

基础知识 - 分片

为什么Redis需要分片?Redis分片可以

  1. 分片后,数据库容量不受单机内存容量限制
  2. 分片能利用多核、多服务器,提高计算能力(一个Redis服务是单线程的)
  3. 分片后,单机网络带宽压力减少。

为什么选择哈希分片(hash partitioning)?

最简单的分片方式是范围分片,不过范围分片要维护一个映射范围到实例的表,这种方式效率低。

 例如:如果我们的数据是user的形式,我们可以把user<0>到user<1000>的数据存到1号Redis实例,把user<10001>到user<20000>存到2号Redis实例,依此类推。但如果我们还有post, , 等各种不同类型的键,我们需要为每一种类型定义一个映射范围表。这个比较麻烦。

采用哈希分片就没有这个问题。由于Redis自身是一个Key-Value数据库,可以直接对key这个字符串计算hash,得到一个数字,然后对数字取模(模为redis实例数目)。

例如:我们对user<2019>这个键计算哈希得到数字9527520,假设我们有7个Redis实例,9527520 % 7 = 2,我们就能知道这个数据存放在2号Redis实例中。

分片的不同实现

  • 客户端分片(Client side partitioning)意味着,客户端直接选择正确的节点来写入和读取指定键。许多 Redis 客户端实现了客户端分片。
  • 代理协助分片(Proxy assisted partitioning)意味着,我们的客户端发送请求到一个可以理解 Redis 协议的代理上,而不是直接发送请求到 Redis 实例上。代理会根据配置好的分片模式,来保证转发我们的请求到正确的 Redis 实例,并返回响应给客户端。Redis 和 Memcached 的代理 Twemproxy 实现了代理协助的分片。
  • 查询路由(Query routing)意味着,你可以发送你的查询到一个随机实例,这个实例会保证转发你的查询到正确的节点。Redis 集群在客户端的帮助下,实现了查询路由的一种混合形式 (请求不是直接从 Redis 实例转发到另一个,而是客户端收到重定向到正确的节点)。下面所说的Redis Cluster就是采用查询路由的方式。

Redis官方提供的集群实现:Redis Cluster

从 Redis 3.0 开始,Redis提供了一个官方集群实现:Redis Cluster。

上面这两个文档足够了,下面是我的一些理解。

新增或删除结点

RedisCluster通过哈希槽移动、哈希槽百分比调整、重新分片(Reshard)等操作完成增删结点、数据均衡。
这篇博客挺好的,自己动手试试试试能加深理解,CSDN - Redis Cluster增加节点和Reshard

Redis Cluset的主从模型Master-Slave

比如我们有6个Redis实例,可以用分别设置A,B,C三台作为Redis Cluster的主服务器,然后设置A1,A2,A3作为从服务器。这样,当主服务器A宕机后,Redis Cluster会自动将请求重定向到A1服务器。

一定要看的链接

Redis集群学习笔记的更多相关文章

  1. 25.redis集群搭建笔记

    ###Redis集群### 0.准备 软件: redis-3.0.0.gem redis-3.0.0.tar.gz#源码   1.安装ruby环境 redis基于ruby槽位计算,hash算法技术,k ...

  2. redis集群学习

    转载: http://arganzheng.life/redis-cluster.html Redis3.0版本加入了cluster功能,解决了Redis单点无法横向扩展的问题. 分布式系统要解决的不 ...

  3. codis+redis集群学习整理(待续)

    Codis 由四部分组成: Codis Proxy (codis-proxy) Codis Manager (codis-config) Codis Redis (codis-server) ZooK ...

  4. Redis集群搭建笔记

    系统为CentOS7,创建9001-9006 6个文件夹,复制 redis-server redis.conf 文件到6个新文件夹下 redis.conf文件配置如下: port 9001 daemo ...

  5. 【Database】Mysql分布式集群学习笔记

    一.sql 的基本操作 (2018年11月29日,笔记) (1)数据库相关操作 创建数据库.查看数据库.删除数据库 #. 创建数据库 create database mytest default ch ...

  6. [个人翻译]Redis 集群教程(上)

    官方原文地址:https://redis.io/topics/cluster-tutorial  水平有限,如果您在阅读过程中发现有翻译的不合理的地方,请留言,我会尽快修改,谢谢.        这是 ...

  7. Linux 下redis 集群搭建练习

    Redis集群 学习参考:https://blog.csdn.net/jeffleo/article/details/54848428https://my.oschina.net/iyinghui/b ...

  8. Windows下Redis集群配置

    Redis集群学习地址:http://blog.csdn.net/dc_726/article/details/11694437 Windows-32系统下搭建Redis集群 一.Redis主从同步原 ...

  9. Redis集群环境搭建实践

    0 Redis集群简介 Redis集群(Redis Cluster)是Redis提供的分布式数据库方案,通过分片(sharding)来进行数据共享,并提供复制和故障转移功能.相比于主从复制.哨兵模式, ...

随机推荐

  1. Apache下设置网站目录的访问权限

    禁止用户对某一个目录及目录下文件的访问,仅允许本地访问 <Directory "/wwwroot/cert/"> Require local </Director ...

  2. R语言学习笔记:基础知识

    1.数据分析金字塔 2.[文件]-[改变工作目录] 3.[程序包]-[设定CRAN镜像] [程序包]-[安装程序包] 4.向量 c() 例:x=c(2,5,8,3,5,9) 例:x=c(1:100) ...

  3. 非线性方程(组):MATLAB内置函数 solve, vpasolve, fsolve, fzero, roots [MATLAB]

    MATLAB函数 solve, vpasolve, fsolve, fzero, roots 功能和信息概览 求解函数 多项式型 非多项式型 一维 高维 符号 数值 算法 solve 支持,得到全部符 ...

  4. BCB ERROR:[Linker Error] 'XXX.LIB' contains invalid OMF record, type 0x21 (possibly COFF)

    今天C++builder 导入 gts .lib  (gts.dll)库文件 编译报错: [Linker Error] 'D:\...\V4.05.007.1000-20161028\GTS.LIB' ...

  5. SpringMVC学习笔记二第一个小的程序

    首先:我们要用springmvc来写一个helloworld的例子: 首先我们需要导入所需要的架包: /demo1/WebRoot/WEB-INF/lib/commons-logging-1.1.1. ...

  6. VS2010/MFC编程入门之四十一(文档、视图和框架:分割窗口)

    上一节中鸡啄米讲了文档.视图和框架结构中各对象之间的关系,本节主要讲讲在MFC中如何分割窗口. 分割窗口概述       分割窗口,顾名思义,就是将一个窗口分割成多个窗格,在每个窗格中都包含有视图,或 ...

  7. 解决nginx下不能require根目录以外的文件

    我们常规的做法是将统一入口文件.css.js这些放在网站根木,其他php文件放到根目录外部,这个时候nginx访问是require不到的,需要设定一下 1.vi  /usr/local/nginx/c ...

  8. python 元组 序列上使用enumerate()函数

    不能直接for n,x,y in enumerate(data)

  9. Linux基础命令---more

    more 将内容较长的文本文件内容分屏显示,支持定位关键字.此命令的适用范围:RedHat.RHEL.Ubuntu.CentOS.SUSE.openSUSE.Fedora. 1.语法         ...

  10. python3.4学习笔记(十一) 列表、数组实例

    python3.4学习笔记(十一) 列表.数组实例 #python列表,数组类型要相同,python不需要指定数据类型,可以把各种类型打包进去#python列表可以包含整数,浮点数,字符串,对象#创建 ...