Redis主从集群搭建

Redis 版本: Redis-x64-3.2.10

操作系统: Windows 10 64位

Ruby 版本:Ruby-2.5.1-1 64位

RubyGems版本:2.7.6


尝试在windows系统上搭建一个入门级的redis集群,网上多数是Linux系统但无论是Linux上搭建还是在Windows上搭建过程基本一致。

一、Redis集群简介

    1. redis3.0版本之前只支持单例模式,在3.0版本及以后才支持集群;

    2. redis集群没有统一的入口,客户端连接集群中任何节点即可,多个redis节点网络互联,数据共享,每个节点都是一个redis实例;

    3. 任何判断节点是否挂掉?redis-cluster为了实现集群的高可用,采用投票容错机制:如果集群中超过半数的节点投票认为该节点fail,那么这个节点就挂了。具体原理如图:


投票容错机制

    4. redis集群至少需要3个节点,因为集群要采用投票容错机制,所以2个节点无法构成集群;

二、搭建步骤

    1. 下载Redis


    2. 配置三主三从集群

        将解压后的redis文件复制出五份,分别命名为redis6379、redis6380、redis6381、redis6382、redis6383、redis6384。


    3. 修改redis配置文件

        修改六份redis文件中的redis.windows.conf、redis.windows-service.conf两个文件,分别修改以下数据:

port   6379    //修改默认端口号

cluster-enabled yes    //开启集群模式

cluster-config-file nodes-6379.conf        //设定保存节点配置文件的路径,节点文件自动生成,无需修改

cluster-node-timeout 15000        //设置集群超时时间   

appendonly yes        //开启appendonly模式,redis将每次写操作请求追加到appendonly.aof文件中

        注:两个文件的修改内容一样,数据前面不能留有空格

        另外在每个文件中写入一个快速启动脚本,便于快速开启redis,内容如下:

        title redis6379

        redis-server.exe redis.windows.conf

        开启所有reids启动脚本。

    4. 安装ruby

        下载ruby https://pan.baidu.com/s/1smx7za7jrJghRnxM5VZ-Uw 提取码:gi1i,下载完的rubyinstaller默认安装无需勾选其他选项。

    5. 安装rubyGems

        下载并解压(https://pan.baidu.com/s/1tDZYza872SrmCfuUneGCRw 提取码:mv5v),进入文件中运行setup.rb。

    运行时可能会出现上面的错误,这是因为编码错误只需将registry.rb中的LOCALE = Encoding.find(Encoding.locale_charmap)修改成LOCALE = Encoding::UTF_8,保存再次运行。

    6. 下载集群脚本redis-trib.rb

        这个脚本没有太多约束可以在网上下载,也可以使用这个(https://pan.baidu.com/s/1KFZx4sbiZOO25DybU2qvGQ 提取码:qg02)

        运行脚本执行命令redis-trib.rb create --replicas 1 127.0.0.1:6379 127.0.0.1:6380 127.0.0.1:6381 127.0.0.1:6382 127.0.0.1:6383 127.0.0.1:6384,当出现Can I set the above configuration? (type 'yes' to accept),输入yes

        create创建集群,--replicas参数指定集群中每个主节点配备几个从节点,这里设置为1。

            目前为止redis集群就基本完成,当程序最后出现以下状态才算真正的搭建完成。

    7. 测试集群

        进入其中一个redis文件,这里以6379为例,输入命令redis-cli.exe -h 127.0.0.1 -p 6379 -c(h代表主机号,p代表端口号,c代表使用集群),输入set name hello, world,集群会自动保存并跳到6380,然后在6380中能get name取到刚刚存入的值。

    8. 关闭集群

        使用shutdown save|nosave关闭集群。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,711评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,932评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,770评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,799评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,697评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,069评论 1 276
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,535评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,200评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,353评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,290评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,331评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,020评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,610评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,694评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,927评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,330评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,904评论 2 341

推荐阅读更多精彩内容

  • 1 Redis介绍1.1 什么是NoSql为了解决高并发、高可扩展、高可用、大数据存储问题而产生的数据库解决方...
    克鲁德李阅读 5,257评论 0 36
  • redis集群分为服务端集群和客户端分片,redis3.0以上版本实现了集群机制,即服务端集群,3.0以下使用客户...
    hadoop_null阅读 1,581评论 0 6
  • 文章大纲 一、基础知识学习二、Redis常见的几种架构及优缺点总结三、Redis之Redis Sentinel(哨...
    故事爱人c阅读 1,122评论 3 12
  • 1.集群与分布式的概述 1.1 分布式 分布式是指将不同的业务分布在不同的地方. web应用和数据库服务分开 1....
    程序员Darker阅读 453评论 1 1
  • 准备工作 redis集群一般由多个节点组成,节点数至少为6个才能保证组成完整高可用的集群。建议为集群所有的节点配置...
    yeren108阅读 463评论 0 2