由于集群这章节内容较多,也比较重要,所以单独拉出来,做一个小章节。

1:如何搭建一个集群?

  - 环境为 Ubuntu16.04

  - 这里我预计使用 9001 - 9006 端口,生成一个 6 台机器的集群

  - 生成对应目录

  mkdir ~/redis-cluster
  cd redis-cluster
  mkdir -p /data
  mkdir -p /data
  ......
  mkdir -p /data

  - 同时需要配置每个目录下的 Redis.conf 这里以 9001 端口为例

  port (每个节点的端口号)
  cluster-enabled yes(启动集群模式)(必须)
  cluster-config-file nodes9001.conf(9001和port要对应)(必须)

  - 配置完成之后,启动对应服务 这里以 9001 为例(其余同理)

  sudo redis-server ~/redis-cluster//redis.conf

  - 查看 9001 端口的服务会否正常启动

  vagrant@hong:~/redis-cluster$ ps -aux | grep 'redis'
  root 0.0 0.0 ? Ssl : : redis-server 127.0.0.1: [cluster]

  - 这时候集群就已经正常使用了,但是,现在每个节点都是相对独立的。

  - 我们应该把他连接起来。

  - redis 提供的辅助工具可以方便的完成这个任务 redis-trib.rb

  因为是用 Ruby 来写的,所以我们应该先安装它。
  sudo apt-get install ruby
  sudo apt-get install rubygems
  sudo apt-get install redis

  - 安装完成之后,找到这个文件

  sudo find / -name "redis-trib.rb"

  - 初始化集群

  sudo /usr/share/doc/redis-tools/examples/redis-trib.rb create --replicas  127.0.0.1: 127.0.0.1: 127.0.0.1: 127.0.0.1: 127.0.0.1: 127.0.0.1:
  /usr/share/doc/redis-tools/examples/redis-trib.rb

  - 重要参数

  --replicas 1 表示每个数据库拥有的从库为1,所以整个数据库拥有(6/2) = 3 个主库和从库

  - 输出如下,表示集群搭建成功

>>> Creating cluster
>>> Performing hash slots allocation on nodes... // 使用下面三个为主库
Using masters:
127.0.0.1:
127.0.0.1:
127.0.0.1:9003 // 从库监听列表
Adding replica 127.0.0.1: to 127.0.0.1:9001 // 9004(从库) > 9001(主库) ,下同
Adding replica 127.0.0.1: to 127.0.0.1:
Adding replica 127.0.0.1: to 127.0.0.1:9003 // 分配插槽(在一个集群中。所有键都可以分配到16384个插槽中)
M: e456e2ab9792abe01bfd044dc708d550d6efa8a3 127.0.0.1:
slots:- ( slots) master
M: 7b1a201f5f4c5837d0794ca29e9ef85408f0df3e 127.0.0.1:
slots:- ( slots) master
M: 89341ac6f0df97eaf1f974080118ac283b8c1901 127.0.0.1:
slots:- ( slots) master
S: 56a07392b3541f41c6b6421f821280a59c687f96 127.0.0.1:
replicates e456e2ab9792abe01bfd044dc708d550d6efa8a3
S: 34509ad9c1e88fea4d09e95a296cbdbdaa9c2cd4 127.0.0.1:
replicates 7b1a201f5f4c5837d0794ca29e9ef85408f0df3e
S: cf18821f8a3dd9cb110db6d6b63a26dae4dd3189 127.0.0.1:
replicates 89341ac6f0df97eaf1f974080118ac283b8c1901
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All slots covered.

-- 至此,一个集群搭建就完毕了。

2:插槽和键的关系?

  - 在一个集群中,所有的键会被分给 16384 个插槽。

  - 在使用键时,Redis 将每个键名通过算法(CRC16),计算出散列,再取  16384 的余数,使得每个键都可以分配到每个节点中。

  - 在连接 Redis 时,也可以使用  redis-cli -c -p 端口 使命令重定向到可以处理的插槽中

3:集群搭建完成之后,还可以在插入节点么?

  - 当然可以。

新节点:新节点端口> CLUSTER MEET 随便在集群中的一个节点 对应端口

  - 之后我们可以看集群内的节点信息

CLUSTER NODES

  - 但是,值得注意的是,在新加入节点之后,是不会分配任何插槽的,因为之前创建时就已经分配了插槽。

  - 后续再分配插槽是非常不友好的,因为会影响到之前的键。

  - 所以推荐使用预分片,建立足够多的节点,为了以后的大数据量打下基础

 4:集群中的故障恢复

  - 在一个节点中,每个节点都会定期向其他节点发送 PING 命令。

  - 如果某节点没有响应,认为目标节点 疑似下线(类似哨兵的主观下线)

  - 选举,超过一半,则从数据库转成主数据库

  - 如果没有从数据库可以进行恢复,则整个集群默认下线并无法工作。

    - 也可以通过配置修改 cluster-require-full-coverage 使其正常工作。

    - 但是会有一部分负责插槽,无法工作。

  

《Redis 集群》的更多相关文章

  1. 简单物联网:外网访问内网路由器下树莓派Flask服务器

    最近做一个小东西,大概过程就是想在教室,宿舍控制实验室的一些设备. 已经在树莓上搭了一个轻量的flask服务器,在实验室的路由器下,任何设备都是可以访问的:但是有一些限制条件,比如我想在宿舍控制我种花 ...

  2. 利用ssh反向代理以及autossh实现从外网连接内网服务器

    前言 最近遇到这样一个问题,我在实验室架设了一台服务器,给师弟或者小伙伴练习Linux用,然后平时在实验室这边直接连接是没有问题的,都是内网嘛.但是回到宿舍问题出来了,使用校园网的童鞋还是能连接上,使 ...

  3. 外网访问内网Docker容器

    外网访问内网Docker容器 本地安装了Docker容器,只能在局域网内访问,怎样从外网也能访问本地Docker容器? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Docker容器 ...

  4. 外网访问内网SpringBoot

    外网访问内网SpringBoot 本地安装了SpringBoot,只能在局域网内访问,怎样从外网也能访问本地SpringBoot? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装Java 1 ...

  5. 外网访问内网Elasticsearch WEB

    外网访问内网Elasticsearch WEB 本地安装了Elasticsearch,只能在局域网内访问其WEB,怎样从外网也能访问本地Elasticsearch? 本文将介绍具体的实现步骤. 1. ...

  6. 怎样从外网访问内网Rails

    外网访问内网Rails 本地安装了Rails,只能在局域网内访问,怎样从外网也能访问本地Rails? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Rails 默认安装的Rails端口 ...

  7. 怎样从外网访问内网Memcached数据库

    外网访问内网Memcached数据库 本地安装了Memcached数据库,只能在局域网内访问,怎样从外网也能访问本地Memcached数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装 ...

  8. 怎样从外网访问内网CouchDB数据库

    外网访问内网CouchDB数据库 本地安装了CouchDB数据库,只能在局域网内访问,怎样从外网也能访问本地CouchDB数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Cou ...

  9. 怎样从外网访问内网DB2数据库

    外网访问内网DB2数据库 本地安装了DB2数据库,只能在局域网内访问,怎样从外网也能访问本地DB2数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动DB2数据库 默认安装的DB2 ...

  10. 怎样从外网访问内网OpenLDAP数据库

    外网访问内网OpenLDAP数据库 本地安装了OpenLDAP数据库,只能在局域网内访问,怎样从外网也能访问本地OpenLDAP数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动 ...

随机推荐

  1. 24款最好的jQuery日期时间选择器插件

    如果你正在创建一个网络表单,有很多事情你需要在你的应用程序中使用.有时您需要特别的输入,从用户的日期和时间,如发票日期,生日,交货时间,或任何其他此类信息.如果你有这样的需要,可以极大地从动态的jQu ...

  2. Brainfuck反汇编(Python)

    global cs global ip global ss #global sp global ds global bp global tab global out #cs='++++++++++[& ...

  3. Java动态代理与反射详解

    首先我得先请大家不要误会,博客园说转载的文章放在文章分类里,原创的文章用随笔写,我开先还以为随笔是拿来写抒情文的(滑稽),后来才发现不是这样的,但是自己所有的文章都在文章分类里了,又懒得搬运,所以我就 ...

  4. 系统垃圾清理利器CCleaner v5.30.6063绿色单文件版(增强版)

    系统垃圾清理利器CCleaner现已更新至v5.30.6063,此次更新为Edge.IE浏览器提供了更好的清理功能,更新了Windows Explorer MRU清理功能,同时改善了应用程序中的SSD ...

  5. android 监听动画对象后不能播放动画

    采用监听  AnimationListener 发现不能播放动画了. 解决办法: 将动画的启动方式:animation.startnow去掉,改为如下即可 view.startAnimation(an ...

  6. tensorflow模型量化

    tensorflow模型量化/DATA/share/DeepLearning/code/tensorflow/bazel-bin/tensorflow/tools/graph_transforms/t ...

  7. Mysql系列四:数据库分库分表基础理论

    一.数据处理分类 1. 海量数据处理,按照使用场景主要分为两种类型: 联机事务处理(OLTP) 面向交易的处理系统,其基本特征是原始数据可以立即传送到计算机中心进行处理,并在很短的时间内给出处理结果. ...

  8. 大杂烩 -- Java内存布局【图】以及java各种存储区【详解】

    基础大杂烩 -- 目录 -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- 一.Java内存布局浅谈 1. 总述 我们知道,线 ...

  9. linux如何查看某个端口是否开放

    1.你可以使用 lsof 命令来查看某一端口是否开放.查看端口可以这样来使用,我就以80端口为例: lsof -i:80 或者 lsof -i:22如果有显示说明已经开放了,如果没有显示说明没有开放 ...

  10. 170824、storm 环境搭建

    /*********************storm 环境搭建 **********************/ 1 安装jdk1.7 2 安装zookeeper集群环境 3 安装Python2.6. ...