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

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. FROM USE CASES TO TEST CASES

    FROM USE CASES TO TEST CASES -Test note of “Essential Software Test Design” 2015-08-31 Content: 12.1 ...

  2. Linux 常用命令随笔(二)

    Linux 常用命令随笔(二) 1.RPM RPM是RedHat Package Manager(RedHat软件包管理工具) 1.1.安装软件包 rpm -ivh ***.rpm 其中i表示安装,v ...

  3. AbtestingGateway 分流策略添加

    目录结构分布 我们从GitHub上把它下载后解压出来,有以下5个目录,分别是: admin 管理模块,对策略增删改查等功能 diversion 主模块吧,看源码是匹配redis存储的key doc 文 ...

  4. PDF Transformer+与Transformer3.0功能对比

    ABBYY PDF Transformer+是一个新的.全面的巧妙解决PDF文档的工具,它将泰比的光学字符识别(OCR)技术和Adobe®PDF技术完美结合,以确保实现便捷地处理任何类型的PDF文件, ...

  5. spring扩展的常用接口

    一:ApplicationContextAware接口 实现ApplicationContextAware接口,重写setApplicationContext方法,可以将spring容器上下文对象注入 ...

  6. [PHP] 05 - Cookie & Session

    故事背景 同 http, html, REST API 一样属于基础性的知识内容. [Node.js] 07 - Html and Http [Node.js] 08 - Web Server and ...

  7. Window应急响应(一):FTP暴力破解

    0x00 前言 ​ FTP是一个文件传输协议,用户通过FTP可从客户机程序向远程主机上传或下载文件,常用于网站代码维护.日常源码备份等.如果攻击者通过FTP匿名访问或者弱口令获取FTP权限,可直接上传 ...

  8. Markdown 引用

    Markdown 使用 > 来标记区块引用,语法及效果如下: > 这是第一级引用 > > > 这是第二级引用 > > 现在回到第一级引用 > > ...

  9. VS2017 配置freeglut3.0.0

    配置freeglut: 1. 先下载cmake和freeglut3.0.0文件,并使用cmake编译freeglut,再使用vs2017生成解决方案,详细步骤见https://blog.csdn.ne ...

  10. Windows-NTFS-ADS在渗透测试中的利用

    0.什么是ADS Windows:微软公司的一款视窗操作系统,其内核为WindowsNT. NTFS:WindowsNT环境的限制级专用文件系统. ADS:NTFS的系统特性,交换数据流(Altern ...