【Redis】集群教程(Windows)

  1. 概述
  2. Redis集群数据分片
  3. Redis集群节点通讯
  4. 环境准备
  5. 搭建Redis集群
  6. 测试Redis集群

概述

Redis Cluster provides a way to run a Redis installation where data is automatically sharded across multiple Redis nodes

Redis集群提供一个在多个Redis节点数据自动共享的方式,简朴来说就是添加服务器的数目,到达

  • 高可用,让Redis服务长时间有用运行,不会由于硬件/软件问题导致不可用
  • 可扩展性,动态添加节点/删除节点,到达增添性能/削减服务器资源
  • 漫衍式,节点可以不是
  • 容错,若其中一台服务器故障挂了Redis也能继续使用(条件是有从节点而且可用)

 

Redis集群数据分片

Redis 集群没有使用一致性hash, 而是引入了 哈希槽的观点.

Redis 集群有16384个哈希槽,每个key通过CRC16校验后对16384取模来决议放置哪个槽.集群的每个节点卖力一部门hash槽,举个例子,好比当前集群有3个节点,那么:

  • 节点 A 包罗 0 到 5500号哈希槽.
  • 节点 B 包罗5501 到 11000 号哈希槽.
  • 节点 C 包罗11001 到 16384号哈希槽

这种结构的利益就是异常容易增添/删除节点,而且不会影响集群的使用

  • 增添节点,将原来节点的分配部门哈希槽给新节点
  • 删除节点,将删除的节点哈希槽分配给现有的节点上即可

 

Redis集群节点通讯

由于Redis集群是把数据漫衍存放在差别客户端,这样做的利益就是削减每台机械的压力,提高并发处置能力,由于我们只要进入任一节点,即可使用整个集群,这就需要节点之间相互通讯,这个是Redis内部处置。

Every Redis Cluster node requires two TCP connections open. The normal Redis TCP port used to serve clients, for example 6379, plus the port obtained by adding 10000 to the data port, so 16379 in the example

每一个Redis集群节点都是需要两个端口,一个用于客户端毗邻,一个用于节点数据传输(Ping-Pong机制),数据端口是在客户端口的基础上加10000,例如,端口6379,数据端口16379,所以在多台机械部署集群需要注重防火墙是否把数据屏障 。

 

环境准备

1.安装Redis  下载地址

2. 安装Ruby,由于Redis集群治理是用ruby开发  下载地址

3. 下载edis-trib.rb文件,放在Redis安装文件夹内   下载地址

4. 安装Ruby的Redis驱动,直接在cmd执行(安装的时刻把Ruby放在环境变量,否则进到Bin执行)    

gem install redis

泛起Successfully installed 代表安装乐成

【Redis】集群教程(Windows)

 

 

 

LeetCode#21-Merge Two Sorted Lists-合并两个有序链表

搭建Redis集群

Redis集群至少需要3个节点,就按最少的3个节点搭建一个集群

1. 准备3个设置文件,修改各自的端口和appendfilename,固然如果在3台机械上运行,什么都不需要修改

port 6379
cluster-enabled yes
cluster-config-file nodes.6379.conf  
cluster-node-timeout 5000
appendonly yes
appendfilename "appendonly.6379.aof"

 

2. 准备bat文件启动3个redis节点(非必须,可以手动cmd启动,设置响应设置文件),bat文件需要在redis安装目录执行

title redis-cluster
start redis-server.exe redis.6379.conf
start redis-server.exe redis.6380.conf
start redis-server.exe redis.6381.conf

【Redis】集群教程(Windows)

 

3. 用redis-trib建立集群,在cmd执行

redis-trib.rb create 127.0.0.1:6379 127.0.0.1:6380 127.0.0.1:6381

执行完成,输入yes更新设置文件,最终输出各个节点信息,哈希槽分配情况。

 【Redis】集群教程(Windows)

 

至此,Redis集群已经搭建好,这里只有3个主节点,若想从节点,只需多加3个Redis节点,下令加上–replicas参数就可以。

 

测试Redis集群

进入redis-cli集群模式

redis-cli -c

【Redis】集群教程(Windows)

可以看出,写入读取,Redis凭据Key盘算的hash值在各个节点自动重定向

打开刚刚开启的几个Redis实例,可以看出他们之前一直在不停通讯

 【Redis】集群教程(Windows)

转发请标明出处:https://www.cnblogs.com/WilsonPan/p/12643221.html

参考文章

Redis cluster tutorial – Redis

原创文章,作者:28x29新闻网,如若转载,请注明出处:https://www.28x29.com/archives/4435.html