简单说下自己测试搭建简单的Redis集群的大体步骤:

1.首先你的有6个redis(官方说最少6个,3master,3slave),可以先在一台机器上搭建,搭建到多台上应该只需要改变启动命令即可(可能需要一些ssh无密钥什么的,只是猜测)

在网上随便可以找到的配置多个redis,(总体有两种方式,一种是虚拟的,貌似走的都是一个redis,一种是将配置好的redis复制成六份,配置相应的端口等,我选择的后者显得更真实一些)

然后把他们全部打开,可以写一个脚本,或者一个一个打开,作为一个新世纪的年轻人,我当然选择一个一个打开它们......

[root@localhost ~]# ps -ef | grep redis

root      3427    1  0 7月17 ?      00:02:59 src/redis-server *:6379

root      3454    1  0 7月17 ?      00:06:09 src/redis-server *:7001 [cluster]

root      3460    1  0 7月17 ?      00:06:19 src/redis-server *:7002 [cluster]

root      3467    1  0 7月17 ?      00:05:59 src/redis-server *:7003 [cluster]

root      3473    1  0 7月17 ?      00:05:59 src/redis-server *:7004 [cluster]

root      3477    1  0 7月17 ?      00:05:57 src/redis-server *:7005 [cluster]

root      5867    1  0 12:02 ?      00:00:06 src/redis-server *:7000 [cluster]

root      5938  5913  0 13:17 pts/1    00:00:00 grep --color=auto redis

2.将6个独立redis设置为集群,so easy 一句话搞定。其中 --replicas 参数是将6台redis分别分配了主从关系(master挂掉slave可以顶替,但是还没有具体深入研究)

./redis-trib.rb create --replicas 1 127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005

在开启过程中可能会遇到很多问题,各种奇怪的报错,那就要安装ruby和gem的一些东东,搞不明白是什么,反正就是依赖吧~ ,只能说按照这个来会绕开很多坑。

# yum install ruby-devel.x86_64

# wget http://rubygems.global.ssl.fastly.net/gems/redis-3.2.1.gem

# gem install -l ./redis-3.2.1.gem

执行这些代码之后再去执行上面建立集群的命令,如果成功的话,会看到下面的样子:

>>> Creating cluster

Connecting to node 127.0.0.1:7000: OK

Connecting to node 127.0.0.1:7001: OK

Connecting to node 127.0.0.1:7002: OK

Connecting to node 127.0.0.1:7003: OK

Connecting to node 127.0.0.1:7004: OK

Connecting to node 127.0.0.1:7005: OK

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

Using 3 masters:

127.0.0.1:7000

127.0.0.1:7001

127.0.0.1:7002

Adding replica 127.0.0.1:7003 to 127.0.0.1:7000

Adding replica 127.0.0.1:7004 to 127.0.0.1:7001

Adding replica 127.0.0.1:7005 to 127.0.0.1:7002

M: ad52e4f7c14da4b8b1e8e48603c9e5515a4cec7a 127.0.0.1:7000

slots:0-5460 (5461 slots) master

M: d3058a19483d7be5c30c042779e56130f6ebf074 127.0.0.1:7001

slots:5461-10922 (5462 slots) master

M: 5814305e71552ab45c44b9b8233681a63c3a57b1 127.0.0.1:7002

slots:10923-16383 (5461 slots) master

S: e50676757acbe7c6a21e8abf4eda26ababb08285 127.0.0.1:7003

replicates ad52e4f7c14da4b8b1e8e48603c9e5515a4cec7a

S: ab307ba26d6dabe8edb2f2a7287be6f01aa46d88 127.0.0.1:7004

replicates d3058a19483d7be5c30c042779e56130f6ebf074

S: 11174332eb6ad40c0327750536fa776d706caf85 127.0.0.1:7005

replicates 5814305e71552ab45c44b9b8233681a63c3a57b1

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:7000)

M: ad52e4f7c14da4b8b1e8e48603c9e5515a4cec7a 127.0.0.1:7000

slots:0-5460 (5461 slots) master

M: d3058a19483d7be5c30c042779e56130f6ebf074 127.0.0.1:7001

slots:5461-10922 (5462 slots) master

M: 5814305e71552ab45c44b9b8233681a63c3a57b1 127.0.0.1:7002

slots:10923-16383 (5461 slots) master

M: e50676757acbe7c6a21e8abf4eda26ababb08285 127.0.0.1:7003

slots: (0 slots) master

replicates ad52e4f7c14da4b8b1e8e48603c9e5515a4cec7a

M: ab307ba26d6dabe8edb2f2a7287be6f01aa46d88 127.0.0.1:7004

slots: (0 slots) master

replicates d3058a19483d7be5c30c042779e56130f6ebf074

M: 11174332eb6ad40c0327750536fa776d706caf85 127.0.0.1:7005

slots: (0 slots) master

replicates 5814305e71552ab45c44b9b8233681a63c3a57b1

[OK] All nodes agree about slots configuration.

>>> Check for open slots...

>>> Check slots coverage...

[OK] All 16384 slots covered.

3.测试集群。

可以用下面的命令查看集群的状态,从下面可以看出有4个master,2个slave~~~,这个是由于我太年轻kill了7000的redis又加入了进来,原先他的slave 7003 也变成了master顶替了他。

[root@localhost src]# ./redis-trib.rb check 127.0.0.1:7000

Connecting to node 127.0.0.1:7000: OK

Connecting to node 127.0.0.1:7005: OK

Connecting to node 127.0.0.1:7003: OK

Connecting to node 127.0.0.1:7002: OK

Connecting to node 127.0.0.1:7001: OK

Connecting to node 127.0.0.1:7004: OK

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

M: 4eb95ab689288dbb3ebf7ed380a0593ec9daa878 127.0.0.1:7000

slots: (0 slots) master

0 additional replica(s)

S: 11174332eb6ad40c0327750536fa776d706caf85 127.0.0.1:7005

slots: (0 slots) slave

replicates 5814305e71552ab45c44b9b8233681a63c3a57b1

M: e50676757acbe7c6a21e8abf4eda26ababb08285 127.0.0.1:7003

slots:0-5460 (5461 slots) master

0 additional replica(s)

M: 5814305e71552ab45c44b9b8233681a63c3a57b1 127.0.0.1:7002

slots:10923-16383 (5461 slots) master

1 additional replica(s)

M: d3058a19483d7be5c30c042779e56130f6ebf074 127.0.0.1:7001

slots:5461-10922 (5462 slots) master

1 additional replica(s)

S: ab307ba26d6dabe8edb2f2a7287be6f01aa46d88 127.0.0.1:7004

slots: (0 slots) slave

replicates d3058a19483d7be5c30c042779e56130f6ebf074

[OK] All nodes agree about slots configuration.

>>> Check for open slots...

>>> Check slots coverage...

[OK] All 16384 slots covered.

可以进入redis中玩一玩:查了一下使用redis-cli命令的时候应该加上 -c ,意思是在集群模式下,否则你会以一种独立的redis进入,然后各种moved报错。

看着存储位置跳来跳去,貌似简单的集群也就搭建完成了。

[root@localhost src]# ./redis-cli -c -p 7000

127.0.0.1:7000> set linuxidc weikang

-> Redirected to slot [1357] located at 127.0.0.1:7003

OK

127.0.0.1:7003> set linuxidc qiang

OK

127.0.0.1:7003> set weikang linuxidc

-> Redirected to slot [12142] located at 127.0.0.1:7002

OK

127.0.0.1:7002> get linuxidc

-> Redirected to slot [1357] located at 127.0.0.1:7003

"linuxidc"

127.0.0.1:7003> get weikang

-> Redirected to slot [12142] located at 127.0.0.1:7002

"linuxidc"

4.遗留的一些问题:

(1)搭建的集群连接上客户端后,所有的redis只有db0可用,不知道是什么原因。(难道是互相之间只连接了db0吗?)

(2)增删改节点还有待继续研究,不能只是单纯的写命令就可以了,要理解在什么场景下应该做如何的处理。

(3)集群管理工具在redis 3.0之后自己出了一个叫做redis-sentinel的,这个需要着重研究。

只有在深入理解的集群的意义和所配置的每个参数的含义之后,才能使用到生产环境中,以上只是个入门,学习redis集群才只是刚刚开始~~

下面关于Redis的文章您也可能喜欢,不妨参考下:

linux redis集群工具,Redis集群部署及常用的操作命令相关推荐

  1. 微信群里的群工具怎么添加群工具微信

    微信(wechat)是腾讯公司于2011年1月21日推出的一个为智能终端提供即时通讯服务的免费社交程序,微信支持跨通信运营商.跨操作系统平台通过网络快速发送免费(需消耗少量网络流量)语音短信.视频.图 ...

  2. redis php 性能测试工具,redis性能测试与客户端连接详解

    Redis 性能测试(推荐:redis入门教程) 语法redis-benchmark [option] [option value] 实例 实例一 以下实例同时执行 1000 个请求来检测性能:$ r ...

  3. redis集群部署及常用的操作命令_01

    简单说下自己测试搭建简单的redis集群的大体步骤: 1.首先你的有6个redis(官方说最少6个,3master,3slave),可以先在一台机器上搭建,搭建到多台上应该只需要改变启动命令即可(可能 ...

  4. redis主从、哨兵、集群概念

    关于redis主从.哨兵.集群的介绍网上很多,这里就不赘述了. 一.主从 通过持久化功能,Redis保证了即使在服务器重启的情况下也不会损失(或少量损失)数据,因为持久化会把内存中数据保存到硬盘上,重 ...

  5. Redis Client UI工具

    前言 使用Redis做缓存也有一段时间了,一款趁手的UI工具可以省下很多的开发时间.这里,便总结下我所使用的Redis UI 工具. Redis Client 原生工具 Redis Client (g ...

  6. redis 管理工具_Redis桌面管理工具Redis Desktop Manager 2019.2发布

    简介 Redis桌面管理器(又名RDM) - 是适用于Windows,Linux和MacOS的快速开源Redis数据库管理应用程序. 该工具为您提供了一个易于使用的GUI,可以访问您的Redis数据库 ...

  7. linux redis-trib.rb,linux 关于redis-trib.rb构建redis集群

    之前搭建集群漏下的坑, 今次再搭一次. 环境 ruby环境 yum install ruby rubygems -y redis的gem环境 gem install redis-3.2.2.gem 部 ...

  8. Linux上安装集群版Redis

    [前言] 之前自己在Windows中玩过一段时间Redis(感兴趣的朋友可以看下-Redis系列博客),这次在项目中也有幸能负责起Redis,也由于前两天服务器硬盘损坏导致开发的Redis服务器重新装 ...

  9. Redis 集群搭建及集群管理工具

    目录 一.简介 二.架构图 三.搭建集群 3.1.下载 3.2.编译安装 3.3.配置文件修改 3.4.创建集群 四.集群管理工具redis-cli 4.1.查看集群信息 4.2.检查集群 4.3.修 ...

  10. Linux企业化运维--(7)redis服务之redis配置及主从复制、主从自动切换、集群、redis+mysql、gearman实现数据同步

    Linux企业化运维 实验所用系统为Redhat-rhel7.6. 目录 Linux企业化运维 Linux企业化运维--(7)redis服务之redis配置及主从复制.主从自动切换.集群.redis+ ...

最新文章

  1. 2 并发编程--开启进程的两种方式
  2. ERROR: from PIL import Image ImportError: No module named PIL
  3. 重排序、hb、ConcurrentHashMap弱一致性(jdk1.6)
  4. 全字库说文解字字体_整理了10款免费商用中文字体,超好用
  5. java 类及对象的课后作业_JAVA类和对象课后作业
  6. 程序员面试金典 - 面试题 01.02. 判定是否互为字符重排(哈希map)
  7. flash java 6,为Flash构建 Java WebService
  8. 线程进程通信和同步方式
  9. 适时突破[我眼中的戴尔转型]
  10. Atitit webserver tomcat 7 8.0 8.5 9.0新特性 Tomcat 7 的七大新特性 - 编程语言 - ITeye资讯.html tomcat 8.0特性 - CSD
  11. python视频培训班
  12. Unity快速安装教程
  13. java静态代理和动态代理的区别
  14. no-cache和no-store的区别
  15. 说说自己找互联网工作的经验
  16. wps多人协作后怎么保存_在线协同文档分享后,别人只能看却不能写怎么办?
  17. linux学习——echo -n 和echo -e 参数意义
  18. gyctf_2020_foolish_query(C++中的shared ptr指针的误用)
  19. 17种外链方法助你做好外链
  20. 电脑C盘无缘无故就占满了

热门文章

  1. 慕课网仿去哪儿项目笔记--(四)-城市页面的优化
  2. 学习前端的阶段性总结
  3. python成员变量_Python——成员变量
  4. vue的下拉框如何回显_JAVA学习笔记系列:菜鸟Vue学习笔记(三)
  5. laravel mysql增删改查_laravel基础laravle中orm简单的增删改查-一颗优雅草男神你姚哥...
  6. Java中stringbutter_java 中String和StringBuffer与StringBuilder的区别及使用方法
  7. matlab中频谱的实现,如何在MATLAB中实现频谱核函数?
  8. java实现5 4 3 2 1递归_递归及递归的使用
  9. 十进制、二进制、八进制、十六进制转换
  10. 安装protobuf