Redis Cluste部署
一.原生搭建篇Cluster了解cluster的架构
Redis-cluster是使用的是一致性哈希算法来切分数据存储,总计16383个槽,分成16383/N(redis节点)个分区,存取时将key转换成int,key/16383来决定存取在哪个分区。
1.redis.conf配置文件中开启支持cluster集群,改名字为redis-cluster-7000.conf(方便后面集群管理)
port 7000
daemonize yes
pidfile /var/run/redis-7000.pid
dir /opt/module/redis-cluster/data
logfile "7000.log"
dbfilename "dump-7000.rdb"
#开启集群
cluster-enabled yes
#集群中本节点配置文件名 自动生成
cluster-config-file nodes-7000.conf
#当集群中某个节点挂了,整个集群是否停止服务,设置成no 继续提供服务
cluster-require-full-coverage no
2.用上面的配置文件启动redis,确保配置文件没问题
3.用sed命令生成其他节点的配置文件
sed "s/7000/7001/g" redis-cluster-7000.conf >redis-cluster-7001.conf
sed "s/7000/7002/g" redis-cluster-7000.conf >redis-cluster-7002.conf
sed "s/7000/7003/g" redis-cluster-7000.conf >redis-cluster-7003.conf
sed "s/7000/7004/g" redis-cluster-7000.conf >redis-cluster-7004.conf
sed "s/7000/7005/g" redis-cluster-7000.conf >redis-cluster-7005.conf
sed "s/7000/7006/g" redis-cluster-7000.conf >redis-cluster-7006.conf
4.启动每个节点 redis-server redis-cluster-700(1~6).conf
启动后会生成相应的nodes-700(0~6).conf文件。该文件列出了群集中其他节点,它们的状态,持久变量等等。 由于某些消息的接收,通常会将此文件重写并刷新到磁盘上。
5.每个节点互通(meet)
meet通信,保证每个节点能够知道其他节点负责的槽区间。
结构图:
官方:
请注意,Redis 群集需要形成完整的网格(每个节点与其他节点相连,如上图),但为了创建群集,不需要发送形成完整网格所需的所有 CLUSTER MEET 命令。重要的是发送足够的 CLUSTER MEET 消息,以便每个节点都可以通过一系列已知节点到达每个其他节点。
所以只需要有一条通路就可以
进去7000的节点,执行cluster meet 与其他节点通信
redis-cli -p
CLUSTER MEET 127.0.0.1
CLUSTER MEET 127.0.0.1
CLUSTER MEET 127.0.0.1
CLUSTER MEET 127.0.0.1
CLUSTER MEET 127.0.0.1
CLUSTER MEET 127.0.0.1
6.查看是否连通
redis-cli -p cluster info
#结果:
cluster_state:fail #集群状态
cluster_slots_assigned: #被分配的槽位数
cluster_slots_ok: #正确分配的槽位
cluster_slots_pfail:
cluster_slots_fail:
cluster_known_nodes: #当前集群下的所有节点,包括主从节点,7说明通了
cluster_size: #当前集群下的有槽位分配的节点,即主节点
cluster_current_epoch:
cluster_my_epoch:
cluster_stats_messages_ping_sent:
cluster_stats_messages_pong_sent:
cluster_stats_messages_meet_sent:
cluster_stats_messages_sent:
cluster_stats_messages_ping_received:
cluster_stats_messages_pong_received:
cluster_stats_messages_received:
7.分配槽
采用的是一致性哈希算法,来分配总共给定的16383个槽,此处为了方便就均分了,实际开发中建议根据服务器配置分配。
这里使用7001-7003作为主节点 7004-7006做从节点
#此处的分配规则
7001 0~5000
7002 5001~10000
7003 10001~16383
#代码:
redis-cli -p 7001 CLUSTER ADDSLOTS 5000
redis-cli -p 7002 CLUSTER ADDSLOTS 10000
redis-cli -p 7003 CLUSTER ADDSLOTS 16838
结构图:
8.配置主从
这里需要用到Nodeid,第一步中配置生成的文件中可以看
#第一步的配置 可以查看nodes-7000.conf这个文件
cluster-config-file nodes-7000.conf
一一对应:红框为Nodeid
进入每个主节点用 cluster replicate <从Nodeid>
redis-cli -p 7001 cluster replicate da47d14c9e4079ad0973546027f598aab3596fff
查看结果
redis-cli -p 7001 cluster nodes
到此原生配置完成。
下一篇开始Ruby快速搭建Cluster集群。
由于Redis5+移除掉了Ruby,官方说明Redis-trib.rb移到Redis-cli -cluster命令,下一篇没了。
使用redis-cli --cluster快速搭建集群
#前面步骤一样
1.配置主从
多个主从使用"\"隔离开 <几个从>指定多少个从节点
# redis-cli --cluster create <主:port> <从1:port> <从2:port> \ <主1> > <从1> \.... --cluster-replicas <几个从>
./redis-cli --cluster create 127.0.0.1:7001 127.0.0.1:7004 \ 127.0.0.1:7002 127.0.0.1:7005 \ 127.0.0.1:7003 127.0.0.1:7006 --cluster-replicas 1 2.分配槽
#reshard host:port
# --cluster-from <arg>
# --cluster-to <arg>
# --cluster-slots <arg>
# --cluster-yes
# --cluster-timeout <arg>
# --cluster-pipeline <arg>
# --cluster-replace
./redis-cli --cluster reshard 127.0.0.1:7001 --cluster-from 0 --cluster-to 5000
Redis Cluste部署的更多相关文章
- Redis笔记(二)Redis的部署和启动
Linux下Redis的部署和启动 下载安装介质 Redis官网地址:http://www.redis.io/目前最新版本是redis-3.0.3. 可以访问 http://download.redi ...
- Redis分布式部署,一致性hash
一致性哈希 由于hash算法结果一般为unsigned int型,因此对于hash函数的结果应该均匀分布在[0,2^32-1]区间,如果我们把一个圆环用2^32 个点来进行均匀切割,首先按照hash( ...
- Window Redis分布式部署方案 java
Redis分布式部署方案 Window 1. 基本介绍 首先redis官方是没有提供window下的版本, 是window配合发布的.因现阶段项目需求,所以研究部署的是window版本的,其实都 ...
- windows下安装Redis并部署成服务
windows下安装Redis并部署成服务 Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 一:下载 下载地址: windows版本: http ...
- 第一章· Redis入门部署及持久化介绍
Redis简介 Redis安装部署 Redis持久化 Redis简介 软件说明: Redis是一款开源的,ANSI C语言编写的,高级键值(key-value)缓存和支持永久存储NoSQL数据库产品. ...
- VMware虚拟机安装CentOS6.4、部署web项目全过程(设置固定IP、安装JDK、Tomcat、Redis、部署项目)
概述:该篇随笔介绍了在VMware上安装centOS.在centOS上安装JDK.安装Tomcat.安装Redis并部署项目的全过程,虽然参考了很多优秀的文章,但实践.整理.补充都很用心,若要复制粘贴 ...
- Redis 主从部署
Redis 主从部署 http://www.xuchanggang.cn/archives/978.html
- Redis单机部署、添加开机自启、配置参数
1.Redis简介 redis是使用C语言编写的开源的,支持网络,基于内存,可持久性的键值对存储数据库,2013年5月之前,Redis是最流行的键值对存储数据库,Redis采用内存数据集,支持多种数据 ...
- Redis的部署使用文档
Redis的部署使用文档 简述: redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符 串).list(链表).set( ...
随机推荐
- leetcood学习笔记-202-快乐数
题目描述: 方法一:比较笨的办法,根据题意,如果变成1返回True,如果出现重复返回False 看到下面有位朋友用的是dict,我用了list,两个都跑了一下似乎list快一点? class Solu ...
- Dart编程字符串
String数据类型表示一系列字符.Dart字符串是一系列UTF 16代码单元. Dart中的字符串值可以使用 单引号 或 双引号 或 三引号 表示.单行字符串使用单引号或双引号表示.三引号用于表示多 ...
- 阿里云POLARDB如何帮助百胜软件应对数据库的“巅峰时刻”
POLARDB是阿里云自研的下一代关系型云数据库,100%兼容MySQL,存储容量最高可达100TB,性能最高提升至MySQL的6倍,适用于企业多样化的数据库应用场景.POLARDB采用存储和计算分离 ...
- jQuery.speech实现文本转语音播报功能
先放一个实例的地址https://github.com/wenco/speech jQuery.speech是用jQuery写的扩展插件,主要是用来语音播报. 接口调用百度翻译的接口,所以存在url参 ...
- SXOI2018酱油记
Day 0: 嗯前一天刚听说要去参加省选(可能以前也说了不过没听见),作为弱省高一的蒟蒻准备去打打酱油.下午去五中试机啥也没敲晃荡一圈又回去了.今年来也就是打打酱油心情自然是很平静,真不知道明年现在我 ...
- Codeforces 1174A Ehab Fails to Be Thanos
题目链接:codeforces.com/problemset/problem/1174/A 题意:给定长度2n 的数组,改变数组顺序,使得前 n 个数的和不等于 后 n 个数的和,不行输出-1. 思路 ...
- 注意:阿里Druid连接池监控的两个坑
阿里的Druid大家都知道是最好的连接池,其强大的监控功能是我们追求的重要特性.但在实际情况中也有不少坑,说下最近遇到的一个坑吧! 问题1:不断打印error级别的错误日志 session ip ch ...
- USACO2008 Time Management /// 贪心 oj24386
题目大意: 有N个工作被编号为1..N (1 ≤ N ≤ 1,000) 完成第i个工作需要T_i (1 ≤ T_i ≤ 1,000)的时间 第i个工作需在S_i (1 ≤ S_i ≤ 1,000,00 ...
- neo4j常用cypher语句
阅读更多 1.删除带有关系的节点 a.先删除关系 match (n:Node)-[r:关系名称]-() where (n...条件) delete r b.删除节点 match (n:Node ...
- jenkins自动化部署jar包(2)
1.自动化部署流程: svn代码-----jenkins------linux运行 环境: 我这里为了测试:svn,和linux放在阿里云上面.jenkins放在本地windos电脑上运行的 2.下载 ...