如何创建redis集群
1.下载redis源码包
- wget http://download.redis.io/releases/redis-3.2.4.tar.gz
- tar xvf redis-3.2..tar.gz
- cd redis-3.2.4
make && make instal

3.将src文件夹将可执行文件拷贝到/usr/local/bin目录下,因为已经有redis2版本了,所以复制过去之后命名带上3
- cp src/redis-server /usr/local/bin/redis-server3
- cp src/redis-cli /usr/local/bin/redis-cli3
- cp src/redis-trib.rb /usr/bin/redis-trib.rb3
4.创建节点配置文件,至少要6个节点才能创建一个集群【这里示范在同一台机器上创建6个节点来搭建集群,当然你也可以选择两台机器做成3个master和3个slave的形式】
创建6个文件夹并将redis.conf文件复制过去并修改,以7001文件配置为例,后面同步修改7001为7002-7006就可以了
- mkdir -p cluster/7001 cluster/7002 cluster/7003 cluster/7004 cluster/7005 cluster/7006
- cp redis.conf cluster/7001
- vim cluster/7001/redis.conf
主要修改以下几处
- port 7001 //端口7000,7002,7003
- bind 127.0.0.1 //默认ip为127.0.0.1,所以本机可以不写,如果是多台机器需要改为其他节点机器可访问的ip 否则创建集群时无法访问对应的端口,无法创建集群
- daemonize yes //redis后台运行
- pidfile /var/run/redis_7001.pid //pidfile文件对应7000,7001,7002
- cluster-enabled yes //开启集群 把注释#去掉
- cluster-config-file nodes_7001.conf //集群的配置 配置文件首次启动自动生成 7001
- cluster-node-timeout 15000 //请求超时 默认15秒,可自行设置
- appendonly yes //aof日志开启 有需要就开启,它会每次写操作都记录一条日志
5.启动刚刚创建的节点
- redis-server3 cluster/7001/redis.conf
- redis-server3 cluster/7002/redis.conf
- redis-server3 cluster/7003/redis.conf
- redis-server3 cluster/7004/redis.conf
- redis-server3 cluster/7005/redis.conf
- redis-server3 cluster/7006/redis.conf
6.查看redis节点启动情况,出现以下信息说明启动正常
- ps -ef|grep redis
- root 6106 1 0 15:49 ? 00:00:00 redis-server3 127.0.0.1:7001 [cluster]
- root 6112 1 0 15:49 ? 00:00:00 redis-server3 127.0.0.1:7003 [cluster]
- root 6116 1 0 15:49 ? 00:00:00 redis-server3 127.0.0.1:7004 [cluster]
- root 6120 1 0 15:49 ? 00:00:00 redis-server3 127.0.0.1:7005 [cluster]
- root 6124 1 0 15:49 ? 00:00:00 redis-server3 127.0.0.1:7006 [cluster]
- root 6689 1 0 15:50 ? 00:00:00 redis-server3 127.0.0.1:7002 [cluster]
- netstat -tnlp|grep redis
tcp 0 0 127.0.0.1:7001 0.0.0.0:* LISTEN 6106/redis-server3
tcp 0 0 127.0.0.1:7002 0.0.0.0:* LISTEN 6689/redis-server3
tcp 0 0 127.0.0.1:7003 0.0.0.0:* LISTEN 6112/redis-server3
tcp 0 0 127.0.0.1:7004 0.0.0.0:* LISTEN 6116/redis-server3
tcp 0 0 127.0.0.1:7005 0.0.0.0:* LISTEN 6120/redis-server3
tcp 0 0 127.0.0.1:7006 0.0.0.0:* LISTEN 6124/redis-server3
tcp 0 0 127.0.0.1:17001 0.0.0.0:* LISTEN 6106/redis-server3
tcp 0 0 127.0.0.1:17002 0.0.0.0:* LISTEN 6689/redis-server3
tcp 0 0 127.0.0.1:17003 0.0.0.0:* LISTEN 6112/redis-server3
tcp 0 0 127.0.0.1:17004 0.0.0.0:* LISTEN 6116/redis-server3
tcp 0 0 127.0.0.1:17005 0.0.0.0:* LISTEN 6120/redis-server3
tcp 0 0 127.0.0.1:17006 0.0.0.0:* LISTEN 6124/redis-server3
6.创建集群
出现错误,看提示信息原来这个工具是基于ruby实现的,所以需要先安装ruby
- redis-trib.rb3 create --replicas 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 127.0.0.1:7006
- /usr/share/ruby/vendor_ruby/2.0/rubygems/core_ext/kernel_require.rb:55:in `require': cannot load such file -- redis (LoadError)
- from /usr/share/ruby/vendor_ruby/2.0/rubygems/core_ext/kernel_require.rb:55:in `require'
- from /usr/local/bin/redis-trib.rb3:25:in `<main>'
安装ruby,查看yum提供ruby的安装,那直接用yum安装就行了
- yum list|grep ^ruby
- yum -y install ruby ruby-devel rubygems rpm-build
- gem install redis
还是报错,因为直接通过yum安装的ruby版本是2.0.0,而redis集群需要2.2.2+
开始使用源码包安装ruby2.2.2+,但是还是出问题,因为2.0.0版本冲突的问题吧,百度了一下可以使用rvm来安装同时卸载掉原来的2.0.0
- yum install curl
- gpg2 --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 //一定先执行这一步,不然下一步可能会报错
- curl -L get.rvm.io | bash -s stable
- source /usr/local/rvm/scripts/rvm
- rvm list known //查看可安装的版本 可以看到有2.3.3,就安装这个吧
- rvm install 2.3.3
- rvm remove 2.0.0 //干掉就版本
- rvm remove 2.7.9 //干掉就版本
- ruby --version //ruby 2.3.3p222 (2016-11-21 revision 56859) [x86_64-linux] 成功
重新执行gem install redis,成功
重新执行redis-trib.rb3 create --replicas 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 127.0.0.1:7006还是报错
带上一个参数redis-trib.rb3 create --replicas 1 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 127.0.0.1:7006
否则会提示
输入yes后最终出现如图界面,表示成功了
验证是否成功,集群链接带-c参数,如下显示成功了
如何创建redis集群的更多相关文章
- 四十.创建Redis集群 管理集群
环境准备 准备 6台(51-56) redis服务器 以默认配置运行redis服务即可 一.创建Redis集群 1.启用集群功能( 51-56 都要配置) ]# netstat -antupl ...
- 重新创建redis集群的注意事项
一.重新创建redis集群的注意事项 1.将每个节点下aof.rdb.nodes.conf本地备份文件删除: 2.127.0.0.1:7001> flushdb #清空当前数据库(这一步可以省略 ...
- AWS 创建redis 集群模式遇到的问题
问题描述 前几天在aws 平台创建了Redis 集群模式,但是链接集群的时候发现无法连接,返回信息超时. 通过参数组创建redis的时候提示报错:Replication group with spec ...
- 创建redis集群
假设你已经安装好了redis ,如果还没有请安装 将多个实例跑起来 创建一个目录,比如 redis-cluster 把redis-server拷贝到这个目录下 在目录下为每一个实例创建一个文件夹 在每 ...
- docker创建Redis集群
开始工作: yum install wegt ##安装下载工具 yum install net-tools ##安装网络工具 yum install tree ##安装tree命令(方便查看集群配置文 ...
- k8s第一个实例创建redis集群服务
1.创建redis-master-controller.yaml apiVersion: v1 kind: ReplicationController metadata: name: redis-ma ...
- redis-trib.rb创建Redis集群时失败报错解决方案
问题描述: [root@eshop-cache01 init.d]# redis-trib.rb create --replicas 1 192.168.1.110:7001 192.168.1.11 ...
- window下使用Redis Cluster部署Redis集群
日常的项目很多时候都需要用到缓存.redis算是一个比较好的选择.一般情况下做一个主从就可以满足一些比较小的项目需要.在一些并发量比较大的项目可能就需要用到集群了,redis在Windows下做集群可 ...
- [个人翻译]Redis 集群教程(中)
上一篇:http://www.cnblogs.com/li-peng/p/6143709.html 官方原文地址:https://redis.io/topics/cluster-tutorial 水 ...
随机推荐
- mysql远程连接失败的两种解决方法
---恢复内容开始--- (这是转载别人的,因为我觉得很有用,每次都是参考这个的第二种方法解决的,不管你听不听得到,先说声谢谢!也记下来方便大家看看) mysql解决远程不能访问的二种方法,需要的朋友 ...
- (转)Android访问webservice
纠正网上乱传的android调用Webservice方法. 1.写作背景: 笔者想实现android调用webservice,可是网上全是不管对与错乱转载的文章,结果不但不能解决问题,只会让人心烦 ...
- 获取url参数(jq 扩展包)
(function($){ $.extend({ urlGet:function(url) { var getUrl = url ? url.split("?") : window ...
- CSS一些特殊图形
CSS一些特殊图形 CSS绘制三角形 通过控制元素的border属性可以实现三角形效果; 首先来设置4个边框, 为50px solid [color] color设置成不同的颜色值看一下效果 < ...
- centos8 常用软件
防火墙 GUI版 https://blog.csdn.net/qq_36492368/article/details/80432259 dnf install -y firewall-config d ...
- 使用yum安装报错:[Errno 256] No more mirrors to try
背景:我使用yum方式安装软件时,比如zabbix这种软件,我们在安装时一般都是直接到zabbix官网,按照官方的步骤进行安装,但是有一个问题,官方的服务器不在国内,时常会在安装时导致超时报错.此时解 ...
- [TJOI2009] 猜数字 - 中国剩余定理
现有两组数字,每组k个,第一组中的数字分别为:a1,a2,...,ak表示,第二组中的数字分别用b1,b2,...,bk表示.其中第二组中的数字是两两互素的.求最小的非负整数n,满足对于任意的i,n ...
- AdaBoost级联分类器
Haar分类器使用AdaBoost算法,但是把它组织为筛选式的级联分类器,每个节点是多个树构成的分类器,且每个节点的正确识别率很高.在任一级计算中,一旦获得“不在类别中”的结论,则计算终止.只有通过分 ...
- 算法竞赛入门经典第二版 蛇形填数 P40
#include<bits/stdc++.h> using namespace std; #define maxn 20 int a[maxn][maxn]; int main(){ ; ...
- 手机app测试要点(复制文)
一.简介 移动应用App已经渗透到每个人的生活.娱乐.学习.工作当中,令人激动.兴奋且具有创造性的各种App犹如雨后春笋般交付到用户手中.各类智能终端也在快速发布,而开发者对于全球移动设备的质量和性能 ...