条件

  l 基于redis5.0.*版本进行集群的搭建

  l 集群要求至少六个节点,即每个主节点配置1个从节点,本集群是使用了3个主节点并每个下面挂一个从节点,三个主节点分布在3台服务器上

  l 集群配置信息如下:

服务器

Master

Slave

172.16.114.52

7001

7002

172.16.239.95

7003

7004

172.16.239.89

7005

7006

集群配置

在第一台服务器(172.16.114.52)上操作

1. 下载redis源码包并解压

  

wget  -c  http://download.redis.io/releases/redis-5.0.7.tar.gz

tar  -zxvf  redis-5.0.7.tar.gz

2. 新建集群配置目录

mkdir  -p  /usr/local/redis-cluster/7001   /usr/local/redis-cluster/7002

3. 将解压后的文件中的redis.conf配置文件拷贝到集群目录之下 并执行redis安装命令

cd  redis-5.0.7

cp redis.conf  /usr/local/redis-cluster

make  install  PREFIX=/usr/local/redis2  # 注意 这里PREFIX一定是大写

4. 进入/usr/local/redis2,复制bin文件到7001,7002目录下

cd  /usr/local/redis2

cp  -r  bin  /usr/local/redis-cluster/7001

cp  -r  bin  /usr/local/redis-cluster/7002

5.  进入redis-cluster目录,修改redis.conf并分别拷贝到7001,7002

修改配置文件内容如下:

   1) 屏蔽限制本地访问, 将bind 127.0.0.1 修改为 bind  0.0.0.0

  2) protected-mode保护模式从yes改为no

  3) daemonize后的no改为yes

  4) 去掉cluster-enabled yes 前面的注释

  5) 去掉cluster-node-timeout 前面的注释

  6) port后的端口改为7001, 将redis.conf文件,复制到对应的目录下.

cp  redis.conf  7001

  7)  再次编辑redis.conf  将port参数修改 7001 ==> 7002,复制到对应目录下.

sed  -i  's/7001/7002/g'  redis.conf

cp  redis.conf  7002

  8)修改pidfile参数

pidfile /var/run/redis_7001.pid

  9)修改node

cluster-config-file nodes-7001.conf

# 修改为对应的节点ID

6. 启动redis服务

/usr/local/redis-cluster/7001/bin/redis-server /usr/local/redis-cluster/7001/redis.conf

 /usr/local/redis-cluster/7002/bin/redis-server /usr/local/redis-cluster/7002/redis.conf

注意点: 在启动服务之前要修改配置文件中对应的dump dir目录,否则默认目录是  ./  需要改成对应的绝对路径,否则会造成路径冲突,导致启动失败

查看启动的服务:

7.  在另外两台机器上重复以上的操作,需要注意的是,需要设置对应的端口与目录

效果:

第一台(172.16.114.52)

第二台(172.16.239.95):

第三台(172.16.239.89):

集群搭建

使用Redis客户端执行命令:

/usr/local/redis-cluster/7001/bin/redis-cli --cluster create --cluster-replicas 1 172.16.114.52:7001 172.16.114.52:7002 172.16.239.95:7003 172.16.239.95:7004 172.16.239.89:7005 172.16.239.89:7006

参数说明:

--cluster  集群管理命令 后面可以执行集群相关的命令

--cluster-replicas 1 代表每个Master携带一个Slave

create  创建集群命令

至此已经配置成功

客户端测试

  开启客户端 链接任意一个Master节点

/usr/local/redis2/bin/redis-cli -h 172.16.114.52 -c -a 密码 -p 端口

参数:

-c: 连接到集群

我们可以看到,当我们set一个键值对的时候,Redis会自动为我们的key计算CRC16值,然后对16384取模,获取key对应的hash slot,然后通过判断该槽被那个Master所占用,帮我们重定向到那个Master节点,将键值对存入。

查看集群信息:

cluster  nodes

常见问题:

  

  1. 出现节点的状态为handshake并且无法使用cluster  forget 删除掉该节点,节点的唯一ID一直发生变化

解决: 这是因为集群所有的节点都持有该节点的信息,不停的再发起重新连接操作,需要在所有节点上(包括从节点)执行 cluster  forget  xxx操作, 才能彻底移除掉无效节点

  1. 集群中出现无用节点

例如:76e6fb6341fd43aaa1be5b2f8bb68a8c8a0572ae :0@0 slave,fail,noaddr - 1585662914903 1585662914903 6 disconnected

可以将其移除  cluster  forget  76e6fb6341fd43aaa1be5b2f8bb68a8c8a0572ae

Redis集群搭建-多服务器的更多相关文章

  1. Redis集群搭建,伪分布式集群,即一台服务器6个redis节点

    Redis集群搭建,伪分布式集群,即一台服务器6个redis节点 一.Redis Cluster(Redis集群)简介 集群搭建需要的环境 二.搭建集群 2.1Redis的安装 2.2搭建6台redi ...

  2. 二、redis集群搭建

    redis集群搭建 redis3.0后支持集群.集群中应该至少有三个节点,每个节点有一备份节点.需要6台服务器.搭建伪分布式,需要6个redis实例.搭建集群的步骤: 一.安装单机版redis 第一步 ...

  3. Redis集群搭建-韩国庆

    认真一步一步搭建下来,就可以成功.... Redis-cluster集群架构讲解 redis集群专业名词称之为Redis-cluster,redis集群是从3.0版本以后才有的概念,也就是说在3.0之 ...

  4. redis 集群搭建: redis-cluster

    前言 redis数据存储在内存中, 就会受到内存的限制, 大家都知道, 一台电脑, 硬盘可以有1T, 但是内存, 没有听说有1T的内存吧. 那如果数据非常多, 超过一台电脑的内存空间, 怎么办呢? 正 ...

  5. centos redis集群搭建

    说明: 10.0.0.111部署6500,6501,6502三个主节点 10.0.0.222部署6500,6501,6502三个备份节点 1.安装redis:略 2.配置内核参数 # 配置 vm.ov ...

  6. 分享知识-快乐自己:redis集群搭建

    Redis介绍: 1.开源的NoSql数据库 2.C语言编写 3.基于内存运行,并且支持持久化 4.Key value存储 5.是主流的Nosql数据库之一 Redis优点: 1.内存使用方面,表现优 ...

  7. redis集群搭建踩坑笔记

    推荐参考教程:https://blog.csdn.net/pucao_cug/article/details/69250101 错误: from /usr/lib/ruby/2.3.0/rubygem ...

  8. redis集群搭建(简单简单)一台机器多redis

      redis集群搭建 在开始redis集群搭建之前,我们先简单回顾一下redis单机版的搭建过程 下载redis压缩包,然后解压压缩文件: 进入到解压缩后的redis文件目录(此时可以看到Makef ...

  9. 新手redis集群搭建

    redis集群搭建在开始redis集群搭建之前,我们先简单回顾一下redis单机版的搭建过程 下载redis压缩包,然后解压压缩文件:进入到解压缩后的redis文件目录(此时可以看到Makefile文 ...

  10. Redis集群搭建及选举原理

    redis集群简述 哨兵模式中如果主从中master宕机了,是通过哨兵来选举出新的master,在这个选举切换主从的过程,整个redis服务是不可用的.而且哨兵模式中只有一个主节点对外提供服务,因此没 ...

随机推荐

  1. Angular 18+ 高级教程 – Signals

    前言 首先,我必须先说明清楚.Signal 目前不是 Angular 的必备知识. 你的项目不使用 Signal 也不会少了条腿,断了胳膊. Angular 官方维护的 UI 组件库 Angular ...

  2. iPay88 学习笔记

    ipay88 学习笔记 之前弄过 MOLPay 现在弄 ipay88</p><p>差不多的概念 这里记入流程就好了 首先是做订单, 然后通过 merchant key + 订单 ...

  3. LeetCode题集-4 - 寻找两个有序数组的中位数,图文并茂,六种解法,万字讲解

    题目:给定两个大小分别为 m 和 n 的正序(从小到大)数组 nums1 和 nums2.请你找出并返回这两个正序数组的 中位数 . 算法的时间复杂度应该为 O(log (m+n)) . 作为目前遇到 ...

  4. k8s 中的 Ingress 简介

    〇.前言 前边已经介绍了 k8s 中的相关概念和 Service,本文继续看下什么是 Ingress. Ingress 的重要性不言而喻,它不仅统一了集群对外访问的入口,还提供了高级路由.七层负载均衡 ...

  5. RTThread内对##连接符和#转字符串这俩符号的使用

    早就知道这俩符号的意思,最近翻看代码又看到了,仍然觉得熟悉又陌生,主要是自己平时写代码对这俩符号用的比较少.于是特地做个实验,加深下理解.可记的东西不多,这篇随笔算是随手一写吧. 上实验代码: 来源: ...

  6. java基础 -反射笔记

    710,反射快速入门 代码: 先创建一个 re.properties 文件: classfullpath=com.hspedu.Cat method=hi Cat.java package com.h ...

  7. Kubernetes基础(Pod?Label?Namespace?Deployment?Service?)(十二)

    上面我们都是在架构层面了解 Kubernetes,但是似乎没有发现关于容器的说明,Kubernetes 作为容器编排引擎,那么他是怎么去对容器进行编排的呢?在 Kubernetes 集群中抽象了很多集 ...

  8. .NET 开源 EF Core 批处理扩展工具,真好用

    前言 Entity Framework Core(EF Core)作为 .NET 生态系统中受欢迎的对象关系映射器(ORM),其轻量级.可扩展性和支持多个数据库引擎而备受青睐. 本文将介绍一款.NET ...

  9. VB.NET 在 Windows下通过WIn32API获取CPU和内存的使用率

    .net 要获取CPU和内存的使用率,一般是通过 PerformanceCounter 或者 WMI 查询得到,但是如果操作系统经常不正常断电或者别的什么原因,让系统的性能计数器抽风了,可能就会造成初 ...

  10. SVN(Linux)提交时强制写日志

    SVN(Linux)提交时强制写日志 1.创建并修改pre-commit文件 进入svn/code/hooks目录,在svn版本库的hooks文件夹下面,复制模版pre-commit.tmplcp p ...