Redis【第二篇】集群搭建
第一步:准备
1.安装包
ruby-2.4.0.tar.gz
rubygems-2.6.10.tgz
zlib-1.2.11.tar.gz
redis-3.3.2.gem
2. 架构:
名称 | IP | 端口 | 节点属性 |
redisA | 192.168.6.128 | 6379 | 主节点 |
redisB | 192.168.6.128 | 9379 | 从节点 |
redisC | 192.168.6.129 | 6379 | 主节点 |
redisD | 192.168.6.129 | 9379 | 从节点 |
redisE | 192.168.6.130 | 6379 | 主节点 |
redisF | 192.168.6.130 | 9379 | 从节点 |
2. 实例 redis 安装
参照 Redis【第一篇】安装 来安装架构中的实例。
第二步:安装Ruby
1. 版本
ruby-2.4.0
2. 安装
# tar zxvf ruby-2.4..tar.gz
# cd ruby-2.4.
# ./configure prefix=/usr/local/ruby
# make
# make install
3. 设置环境变量
# echo 'export PATH="$PATH:/usr/local/ruby/bin"' >> /etc/profile
# source /etc/profile
4. 测试
# ruby -v
第三步:安装 rubygems
1. 版本
rubygems-2.6.10
2. 安装
# tar zxvf rubygems-2.6..tgz
# cd rubygems-2.6.
# ruby setup.rb
3. 测试
# gem -v
第四步:安装zlib
1. 版本
zlib-1.2.11.tar.gz
2. 安装
# tar zxvf zlib-1.2..tar.gz
# cd zlib-1.2.
# ./configure --prefix=/usr/local/zlib
# make
# make install
第五步:安装 ruby-zlib
1. 版本
为 ruby-2.4.0 包中的文件。
2. 安装
# cd ruby-2.4./ext/zlib
# ruby ./extconf.rb --with-zlib-dir=/usr/local/zlib
# make
# make install
返回信息:
第六步:安装 redis-3.3.2.gem
1. 版本
redis-3.3.2.gem
2. 安装
gem install -l redis-3.3.2.gem
返回信息:
第七步:启动
1. 分别修改各个 redis 的配置文件
# cp redis.conf redis-cluster.conf
# vi redis-cluster.conf
编辑配置文件:
1)更改的内容:
daemonize no 更改为 daemonize yes
logfile "" 更改为 logfile "/root/redisA/logs/redis.log" # 需要创建 logs 目录
dir ./ 更改为 dir /root/redisA/data #需要创建 data 目录
appendonly no 更改为 appendonly yes
2)去掉注释的内容
# cluster-enabled yes
# cluster-config-file nodes-.conf
# cluster-node-timeout
# cluster-slave-validity-factor
# cluster-migration-barrier
# cluster-require-full-coverage yes
2. 分别启动各个 redis 服务
# ./src/redis-server redis-cluster.conf
第八步:测试
1. 查看进程
# ps -ef|grep redis|grep -v grep
2. 查看日志
第九步:建立集群
1. 执行命令
# ./src/redis-trib.rb create --replicas 192.168.6.128: 192.168.6.128: 192.168.6.129: 192.168.6.129: 192.168.6.130: 192.168.6.130:
--replicas 1 表示每个主节点下有一个从节点。
默认是前三个为主节点,后三个为从节点。
默认情况下不能从 slaves 读取数据,但建立连接后,执行一次命令 READONLY,该 slaves 即可读取数据。
2. 返回信息
>>> Creating cluster
Connecting to node 192.168.6.128:: OK
Connecting to node 192.168.6.128:: OK
Connecting to node 192.168.6.129:: OK
Connecting to node 192.168.6.129:: OK
Connecting to node 192.168.6.130:: OK
Connecting to node 192.168.6.130:: OK
>>> Performing hash slots allocation on nodes...
Using masters:
192.168.6.128:
192.168.6.129:
192.168.6.130:
Adding replica 192.168.6.129: to 192.168.6.128:
Adding replica 192.168.6.128: to 192.168.6.129:
Adding replica 192.168.6.130: to 192.168.6.130:
M: 31f6b90cfe190d94f39bef42449bdb7efe1b85b0 192.168.6.128:
slots:- ( slots) master
S: 02c6f0321ebbaf52fe42dd372e5daf179ca77853 192.168.6.128:
replicates 90fec8236d68d9e89262a1ae101056fa1da6df25
M: 90fec8236d68d9e89262a1ae101056fa1da6df25 192.168.6.129:
slots:- ( slots) master
S: 5cf4bd75f93514e1895f8bb5bb7042ae23f277e7 192.168.6.129:
replicates 31f6b90cfe190d94f39bef42449bdb7efe1b85b0
M: 82889edd96156daa109e84868ceda24a0272ee82 192.168.6.130:
slots:- ( slots) master
S: 9e238a85863ea02fc534fc870db4f47fd79b9ef6 192.168.6.130:
replicates 82889edd96156daa109e84868ceda24a0272ee82
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 192.168.6.128:)
M: 31f6b90cfe190d94f39bef42449bdb7efe1b85b0 192.168.6.128:
slots:- ( slots) master
additional replica(s)
M: 90fec8236d68d9e89262a1ae101056fa1da6df25 192.168.6.129:
slots:- ( slots) master
additional replica(s)
S: 5cf4bd75f93514e1895f8bb5bb7042ae23f277e7 192.168.6.129:
slots: ( slots) slave
replicates 31f6b90cfe190d94f39bef42449bdb7efe1b85b0
S: 9e238a85863ea02fc534fc870db4f47fd79b9ef6 192.168.6.130:
slots: ( slots) slave
replicates 82889edd96156daa109e84868ceda24a0272ee82
M: 82889edd96156daa109e84868ceda24a0272ee82 192.168.6.130:
slots:- ( slots) master
additional replica(s)
S: 02c6f0321ebbaf52fe42dd372e5daf179ca77853 192.168.6.128:
slots: ( slots) slave
replicates 90fec8236d68d9e89262a1ae101056fa1da6df25
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All slots covered.
集群创建成功!
第十步:测试
1. 客户端连接
# ./src/redis-cli -c -h 192.168.6.128 -p
连接成功则返回:
2. 存取数据
1)连接192.168.6.128的6379端口,并存入数据
2)连接192.168.6.130的9379端口,并读取数据
此时,redis 的三主三从集群已搭建成功!
Redis【第二篇】集群搭建的更多相关文章
- Redis 3.0 集群搭建
Redis 3.0 集群搭建 开启两个虚拟机 分别在两个虚拟机上开启3个Redis实例 3主3从两个虚拟机里的实例互为主备 下面分别在两个虚拟机上安装,网络设置参照codis集群的前两个主机 分别关闭 ...
- Redis 5.0 集群搭建
Redis 5.0 集群搭建 单机版的 Redis 搭建 https://www.jianshu.com/p/b68e68bbd725 /usr/local/目录 mkdir redis-cluste ...
- Redis进阶实践之十一 Redis的Cluster集群搭建
一.引言 本文档只对Redis的Cluster集群做简单的介绍,并没有对分布式系统的详细概念做深入的探讨.本文只是提供了有关如何设置集群.测试和操作集群的说明,而不涉及Redis集群规范中涵 ...
- 超详细的 Redis Cluster 官方集群搭建指南
今天从 0 开始搭建 Redis Cluster 官方集群,解决搭建过程中遇到的问题,超详细. 安装ruby环境 因为官方提供的创建集群的工具是用ruby写的,需要ruby2.2.2+版本支持,rub ...
- redis整合Spring集群搭建及业务中的使用
1.redis安装 Redis是c语言开发的. 安装redis需要c语言的编译环境.如果没有gcc需要在线安装.yum install gcc-c++ 安装步骤: 第一步:redis的源码包上传到li ...
- linux Redis 5.0集群搭建
文档结构如下: Redis cluster 是redis的分布式解决方案,在3.0版本正式推出后,有效的解决了redis分布式方面的需求:当遇到单机内存,并发,流量等瓶颈是,可以采用cluster架构 ...
- redis主从和集群搭建
主从搭建 redis的主从搭建非常简单,打开配置文件6379.conf,只需要将主节点的protected-mode设置为no,然后在从节点配置中加入:slaveof <masterip> ...
- Redis操作及集群搭建以及高可用配置
NoSQL - Redis 缓存技术 Redis功能介绍 数据类型丰富 支持持久化 多种内存分配及回收策略 支持弱事务 支持高可用 支持分布式分片集群 企业缓存产品介绍 Memcached: 优点:高 ...
- Redis 3.0集群搭建/配置/FAQ
·声明 1,已官网中文教程为基础,边看边学,结合环境现状搭建. 2,哥对Ruby不热爱.不熟悉.不感冒,所述内容如有疑义请谅解. 3,3.0官说集群还在测试中,其实用用也还算马马虎虎,对外集群API真 ...
- Redis Cluster 官方集群搭建指南
安装ruby环境因为官方提供的创建集群的工具是用ruby写的,需要ruby2.2.2+版本支持,ruby安装需要指定openssl. 安装openssl $ wget https://www.open ...
随机推荐
- "SQLServer复制需要有实际的服务器名称才能连接到服务器,请指定实际的服务器名"转
"SQLServer复制需要有实际的服务器名称才能连接到服务器,请指定实际的服务器名" 2014-06-12 12:01:10 最近在学习SQL SERVER的高级复制技术的时候 ...
- 安卓版php服务器的mysql数据库增删改查简单案例
界面: index.php文件: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "h ...
- 二叉树最大路径和-Binary Tree Maximum Path Sum
Given a binary tree, find the maximum path sum. For this problem, a path is defined as any sequence ...
- SVG的a链接
SVG的a链接: <%@ page language="java" contentType="text/html; charset=UTF-8" page ...
- sqlserver怎么将查询出来的数据存到新的数据库表中
查询结果直接创建一个新表存放select * into [新表名] FROM [原表名]WHERE 车辆='小汽车' 若新建表要放在另一个数据库B中USE BGOSELECT * INTO [新表名] ...
- HTML5 JavaScript API
W3C官方指定的HTML5规范已经修订了很多次,HTML5这个概念是与javascript API相捆绑的语义标记.在过去这些年中,HTML5这个词所指代的范围正以惊人的的速度膨胀,某种程度上已经成为 ...
- 【JAVA笔记】JAVA后端实现统一扫码支付:微信篇
最近做完了一个项目,正好没事做,产品经理就给我安排了一个任务. 做一个像收钱吧这样可以统一扫码收钱的功能. 一开始并不知道是怎么实现的,咨询了好几个朋友,才知道大概的业务流程:先是开一个网页用 ...
- 循环语句——for语句
一.for语句结构:for (初始化表达式; 循环条件表达式 ;循环后的操作表达式 ) { 执行语句: } 循环条件表达式,必须是true或false 示例: class ForDemo { publ ...
- 微端启动器LAUNCHER的制作之MFC版二(下载)
用了C#再回来用C++写真的有一种我已经不属于这个世界的感觉.C++的下载就没有C#那么方便了,我用的是libcurl.dll,官网上下载的源码自己cmake出来编译的,c++的库引用有debug和r ...
- ZeroMQ初探
概述 ZeroMQ(也称为 ØMQ,0MQ 或 zmq)是一个可嵌入的网络通讯库(对 Socket 进行了封装). 它提供了携带跨越多种传输协议(如:进程内,进程间,TCP 和多播)的原子消息的 so ...