Redis集群创建

redis集群一直是后台开发的重点,自己搭建一个Redis集群并探究集群是对自己非常有帮助的事,本篇文章重点现在我们先搭建一个Redis集群,对Redis其他的知识点将写在后续的文章中。

1:机器环境

    Redis集群搭建的方式有多种,例如Redis主从复制、Sentinel高可用集群等,但从Redis 3.0之后版本支持Redis-cluster集群,Redis-Cluster采用无中心结构,每个节点保存数据和整个集群状态,每个节点都和其他所有节点连接。

Redis > 3.0

linux: CentOS 7.2

2:下载redis

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

tar -zxvf  redis-4.0.8.tar.gz

解压之后会生成 redis-4.0.8 目录

3:编译

cd redis-4.0.8

make

cd src & make test

编译完成之后,你在src目录下能看到这些bin文件:

-rwxr-xr-x 1 root root 2432992 Apr 10 13:34 redis-benchmark 

-rwxr-xr-x 1 root root 25176 Apr 10 13:34 redis-check-aof 

-rwxr-xr-x 1 root root 5192440 Apr 10 13:34 redis-check-rdb 

-rwxr-xr-x 1 root root 2586080 Apr 10 13:34 redis-cli  

lrwxrwxrwx 1 root root 12 Apr 10 13:34 redis-sentinel 

-rwxr-xr-x 1 root root 5192440 Apr 10 13:34 redis-server   

命令解释:

    redis-server:Redis 服务端的启动程序 。

    redis-cli:Redis客户端程序,也可以用 telnet 根据其纯文本协议来操作Redis缓存。

    redis-benchmark:Redis 性能测试工具,测试 Redis 在当前系统下的读写性能。

    redis-check-aof:数据修复。

    redis-check-dump:检查导出工具。     

3:集群

    Redis集群最低需要3主3从的实例,所以需要你启动6份Redis,你可以将上面3编译的文件拷贝成6份,可以放在 /opt/redis_cluster 目录下

(1):cd /opt & mkdir redis_cluster

(2):cp  -r  /opt/redis-4.0.8  ./redis_cluster

(3):mv  redis-4.0.8 redis-6380

重复操作(2)、(3)操作,生成 redis-6381、redis-6382、redis-6383、redis-6384、redis-6385 五份redis目录。

现在假定我们三主三从如下:

    Master:127.0.0.1:6380                 Slave:127.0.0.1:6383

    Master:127.0.0.1:6381                 Slave: 127.0.0.1:6384 

    Master:127.0.0.1:6382                 Slave: 127.0.0.1:6385 

创建集群数据的存放目录:

    cd / & mkdir /data/redis

    cd /data/redis

    mkdir -p 6380  6381    6382    6383    6385   63805

4:修改配置文件 redis.conf

(1):cd /opt/redis_cluster/redis-6380

(2):vim redis.conf

            port 6380

            pidfile /data/6380/redis.pid

            logfile /data/6380/redis.log

            loglevel notice

            dir /data/6380

            dbfilename dump.rdb

            protected-mode no  # 禁用保护模式(避免影响主从复制)

            cluster-enabled yes  # 开启cluster模式 

            cluster-config-file nodes.conf   # 记录集群信息,cluster集群自动维护,不用手动更新、创建

            cluster-node-timeout 5000  # 节点超时时间,目标节点超过指定时间没响应,就标记为FAIL或PFAIL(可能宕机)

            appendonly yes

依次进入redis-6381、redis-6382、redis-6383、redis-6384、redis-6385,根据(2)操作依次修改各自目录的redis.conf文件

5:安装redis-trib.rb需要的依赖环境

安装Epel源:wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo

安装Ruby环境:yum install ruby rubygems -y

使用国内源: gem sources --add http://mirrors.aliyun.com/rubygems/ --remove https://rubygems.org/

检查源: gem sources -l

            *** CURRENT SOURCES ***

            http://mirrors.aliyun.com/rubygems/

安装依赖软件: gem install redis -v 3.3.3

拷贝redis-trib.rb 文件:cp  /opt/redis_cluster/redis-6380/src/redis-trib.rb   /opt/redis_cluster

6:启动各Redis实例

/opt/redis_cluster/redis-6380/src/redis-server /opt/redis_cluster/redis-6380/redis.conf

/opt/redis_cluster/redis-6381/src/redis-server /opt/redis_cluster/redis-6382/redis.conf

......

7:启动集群

/opt/redis_cluster/redis-trib.rb  create  --replicas  1  192.168.190.128:6380  192.168.190.128:6381   192.168.190.128:6382  192.168.190.128:6383  192.168.190.128:6384  192.168.190.128:6385

注意:不建议使用127.0.0.1这样的ip,可能会造成客户端无法连接到集群

命令参数的含义:

选项 create 表示希望创建一个新的集群。

选项 --replicas 1 表示希望集群中的每个主节点创建一个从节点。

之后跟着的多个host:port参数,则是实例的地址列表,希望程序使用这些地址所指示的实例来创建新集群。

ERROR错误提示:如果集群节点少于6个,使用redis-trib.rb创建集群会提示如下信息

>>> Creatingcluster

ERROR: Invalid configuration for cluster creation.

Redis Cluster requires at least 3 master nodes.

This is not possible with 4 nodes and 1 replicas per node.

At least 6 nodes are required.

redis-trib 会打印出一份预想中的配置,如果没问题就可以输入 yes ,redis-trib 就会将这份配置应用到集群当中

>>> Creating cluster

>>> Performing hash slots allocation on 6 nodes...

Using 3 masters:

127.0.0.1:6380

127.0.0.1:6381

127.0.0.1:6382

Adding replica 127.0.0.1:6384 to 127.0.0.1:6380

Adding replica 127.0.0.1:6385 to 127.0.0.1:6381

Adding replica 127.0.0.1:6383 to 127.0.0.1:6382

>>> Trying to optimize slaves allocation for anti-affinity

[WARNING] Some slaves are in the same host as their master

M: 377d7ce63974c82f5b3fcf4e5892ea7a3a6932b9 127.0.0.1:6380

  slots:0-5460 (5461 slots) master

M: 7eb9d21556d11826c420b61ed98aa2107b9dc36c 127.0.0.1:6381

  slots:5461-10922 (5462 slots) master

M: e7dcd03ebbd21de2e8333544005e117ade5770ed 127.0.0.1:6382

  slots:10923-16383 (5461 slots) master

S: e7576762471f895ea9d86d85a901505deb9357b2 127.0.0.1:6383

  replicates 377d7ce63974c82f5b3fcf4e5892ea7a3a6932b9

S: 231e980c377d0dce3165fb2a6c77dc662ea3c29c 127.0.0.1:6384

  replicates 7eb9d21556d11826c420b61ed98aa2107b9dc36c

S: 349a793ae2f95a7dbf15e63e2e5a7777f3be11ac 127.0.0.1:6385

  replicates e7dcd03ebbd21de2e8333544005e117ade5770ed

Can I set the above configuration? (type 'yes' to accept): yes

>>> Nodes configuration updated

>>> Assign a different config epoch to each node

>>> Sending CLUSTER MEET messages to join the cluster

Waiting for the cluster to join.

>>> Performing Cluster Check (using node 127.0.0.1:6380)

M: 377d7ce63974c82f5b3fcf4e5892ea7a3a6932b9 127.0.0.1:6380

  slots:0-5460 (5461 slots) master

  1 additional replica(s)

M: 7eb9d21556d11826c420b61ed98aa2107b9dc36c 127.0.0.1:6381

  slots:5461-10922 (5462 slots) master

  1 additional replica(s)

S: 349a793ae2f95a7dbf15e63e2e5a7777f3be11ac 127.0.0.1:6385

  slots: (0 slots) slave

  replicates e7dcd03ebbd21de2e8333544005e117ade5770ed

S: e7576762471f895ea9d86d85a901505deb9357b2 127.0.0.1:6383

  slots: (0 slots) slave

  replicates 377d7ce63974c82f5b3fcf4e5892ea7a3a6932b9

M: e7dcd03ebbd21de2e8333544005e117ade5770ed 127.0.0.1:6382

  slots:10923-16383 (5461 slots) master

  1 additional replica(s)

S: 231e980c377d0dce3165fb2a6c77dc662ea3c29c 127.0.0.1:6384

  slots: (0 slots) slave

  replicates 7eb9d21556d11826c420b61ed98aa2107b9dc36c

[OK] All nodes agree about slots configuration.

>>> Check for open slots...

>>> Check slots coverage...

[OK] All 16384 slots covered.

8:测试集群

/opt/redis_cluster/redis-6380/src/redis-cli -c -p 6380

127.0.0.1:6380> set msg "oldboy"

-> Redirected to slot [6257] located at 127.0.0.1:6381

OK

127.0.0.1:6381> get msg

"oldboy"

参考链接:实现Redis Cluster集群并实现Python链接集群

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

推荐阅读更多精彩内容