简单说下自己测试搭建简单的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
<span style="color:#009900;">[OK] All nodes agree about slots configuration.</span>
>>> Check for open slots...
>>> Check slots coverage...
<span style="color:#009900;">[OK] All 16384 slots covered.</span></span>  

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:7000slots: (0 slots) master0 additional replica(s)
S: 11174332eb6ad40c0327750536fa776d706caf85 127.0.0.1:7005slots: (0 slots) slavereplicates 5814305e71552ab45c44b9b8233681a63c3a57b1
M: e50676757acbe7c6a21e8abf4eda26ababb08285 127.0.0.1:7003slots:0-5460 (5461 slots) master0 additional replica(s)
M: 5814305e71552ab45c44b9b8233681a63c3a57b1 127.0.0.1:7002slots:10923-16383 (5461 slots) master1 additional replica(s)
M: d3058a19483d7be5c30c042779e56130f6ebf074 127.0.0.1:7001slots:5461-10922 (5462 slots) master1 additional replica(s)
S: ab307ba26d6dabe8edb2f2a7287be6f01aa46d88 127.0.0.1:7004slots: (0 slots) slavereplicates 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 qiang weikang
-> Redirected to slot [1357] located at 127.0.0.1:7003
OK
127.0.0.1:7003> set qiang qiang
OK
127.0.0.1:7003> set weikang qiang
-> Redirected to slot [12142] located at 127.0.0.1:7002
OK
127.0.0.1:7002> get qiang
-> Redirected to slot [1357] located at 127.0.0.1:7003
"qiang"
127.0.0.1:7003> get weikang
-> Redirected to slot [12142] located at 127.0.0.1:7002
"qiang"

转载于:https://www.cnblogs.com/lvcisco/p/10309513.html

redis集群部署及常用的操作命令_01相关推荐

  1. Redis集群部署文档(Ubuntu15.10系统)

    Redis集群部署文档(Ubuntu15.10系统) (要让集群正常工作至少需要3个主节点,在这里我们要创建6个redis节点,其中三个为主节点,三个为从节点,对应的redis节点的ip和端口对应关系 ...

  2. 3.redis集群部署3主3从

    redis集群部署 一:安装redis (使用redis3.0.6版本),同<1.redis安装> 1.下载源码 $ tar xzf redis-3.0.6.tar.gz $ cd red ...

  3. redis集群部署步骤

    1.yum 安装依赖 yum install gcc unzip wget 2.编译安装redis,编译安装的目的是源码包内包含了接下来创建redis集群所需要的 redis-trib.rb脚本 ma ...

  4. redis集群部署一直卡在Waiting for the cluster to join ......

    2019独角兽企业重金招聘Python工程师标准>>> 里是redis多机多节点集群部署的问题解决! 这个是困扰了我最久的问题,使用cluster meet ip port命令无效, ...

  5. Redis集群部署(半自动)

    1.安装Redis 参考:Redis单机版半自动安装 2.集群配置 方便起见我们是用一台虚拟机部署集群,使用不同的端口号进行区分不同的节点,规划如下表: 角色 IP 端口号 master-0 127. ...

  6. 云服务器Redis集群部署及客户端通过公网IP连接问题

    目录 1.配置文件 2.启动服务并创建集群 (1)启动6个Redis服务 (2)通过客户端命令创建集群 3.客户端连接 (1)客户端配置 (2)测试用例 (3)错误日志分析 4.问题解决 (1)查re ...

  7. Redis集群部署的三种方式

    Redis集群的部署方式: 1.主从复制:2.Sentinel哨兵机制:3.cluster集群. 第一种集群方式,部署简单,分为一主一从,或一主N从.数据分布是在所有节点通过replication复制 ...

  8. Redis集群部署的三种模式

    一.Redis简介 Redis 是一款完全开源免费.遵守BSD协议的高性能(NOSQL)的key-value数据库.它使用ANSI C语言编写,支持网络.可基于内存亦可持久化的日志型.Key-Valu ...

  9. redis集群部署及应用场景

    概述 redis cluster大家喜欢叫它redis集群,也有人喜欢叫分片集群.总结下来,redis有三种模式,分别是单机,哨兵模式,分片集群.从表面上看使用的机器越来越多了,其实确实是随着数据量读 ...

最新文章

  1. AlphaGo Zero的伟大与局限——ResNet作者、旷视研究院院长孙剑深度评述
  2. [译]使用LazZiya.ExpressLocalization开发多语言支持的ASP.NET Core 2.x项目
  3. 美国硅谷预测10年后的世界,再不懂你就落伍了
  4. python装饰器_Python基础-装饰器
  5. Spring Cloud Sleuth + Zipkin + RabbitMQ +MySQL(三)
  6. sqlite 迁移 oracle,Oracle 数据导入 Sqlite
  7. 华为波兰销售总监被捕;苹果将推三款新 iPhone;ofo 用冻结款还债 | 极客头条...
  8. C++之左值引用与右值引用
  9. python运维系统开发_老男孩Python运维系统开发教程
  10. Python数据可视化库汇总整理
  11. 粒子群优化算法及其应用
  12. STC单片机代码烧录
  13. python实现简单的聊天小程序
  14. 「ZigBee模块」基础实验(1)点亮LED
  15. php pcntl_alarm,pcntl_alarm定时闹钟信号详解
  16. python 列表推导 为什么快_Python中简单的列表推导式,却能解决复杂的问题,你学会了吗?...
  17. 计算机通信理论——问题问答
  18. FTP协议的原理及配置
  19. 高校供需撮合交易平台规范管理及创新发展
  20. MDD 建模驱动设计

热门文章

  1. mongodb 部署
  2. web worker原理 SSE原理
  3. 【HTTP 2】简介(Introduction)
  4. error: gnu/stubs-32.h: No such file or directory
  5. 《浅谈架构之路:前后端分离模式》
  6. [c++] - 简单的冒泡
  7. 从excel表中生成批量SQL,将数据录入到数据库中
  8. 一、Java语言基础(4)_方法和数组——数组
  9. 第 36 章 RRDTool
  10. C++ exit 与 return 浅析