centos7安装redis-4.0.1集群
试验机操作系统:CentOS Linux release 7.2.1511 (Core)
本文的目的是教会大家快速搭建redis集群,完了再深入学习。
试问如果不上手试验,看的资料再多有个毛用?
下载redis
下载网址:https://redis.io/download
写文章时最新版本为:redis-4.0.1.tar.gz

可以先下载到windows操作系统,然后拷贝到centos。
下载成功后,在centos上创建一个目录,存放我们的软件,我比较喜欢放在/soft目录下。
[root@localhost /]# mkdir /soft
然后利用WinScp工具拷贝到centos系统,放在/soft/目录下。
安装gcc
[root@localhost ~]# yum install gcc
中间有2次提示,要求输入:yes 或 y,我们按照提示来就可以。
安装pstree
[root@localhost ~]# yum install psmisc
中间有1次提示,要求输入:y。按照提示来就可以。
解压tar包
[root@localhost /]# cd /soft
[root@localhost soft]# tar zxvf redis-4.0.1.tar.gz
[root@localhost soft]# mv redis-4.0.1 /usr/local/redis
编译安装
[root@localhost soft]# cd /usr/local/redis
[root@localhost redis]# make MALLOC=libc
[root@localhost redis]# make & make install
说明:如果在make的时候不指定内存管理方式,会报错的:
zmalloc.h:50:31: 致命错误:jemalloc/jemalloc.h:没有那个文件或目录。
malloc是管理内存碎片的。
启动reids
[root@localhost redis]# src/redis-server redis.conf
如果成功,如下图:

然后新开终端,打开redis客户端
[root@localhost ~]# cd /usr/local/redis/
[root@localhost redis]# src/redis-cli

表示已经启动成功。
我相信单机安装有点linux基础的同学都能安装成功。
-------------------------------------------------------------------------------
Redis集群
redis集群要求最小3主3从。我这里跟其它介绍的不一样,我是模拟的真机环境。
准备6台centos7服务器,其中192.168.1.80我们刚刚装了redis,并启动成功。
因为redis集群还需要安装ruby,还需要配置集群,所以我的想法是先在一台机器上安装好之后,我们再拷贝整个系统到其它5台机器。这样我们做的重复工作就比较少了。
192.168.1.80
192.168.1.81
192.168.1.82
192.168.1.83
192.168.1.84
192.168.1.85
安装ruby
在刚安装好的redis服务器上安装ruby
因为创建集群时需要用Ruby 运行redis-trib.rb
[root@localhost redis]# yum -y install ruby ruby-devel rubygems rpm-build
[root@localhost redis]# gem install redis
这条命令有点慢,稍等片刻即可安装成功,如下图:

修改redis.conf
打开redis.conf,把下面列出来的配置项全部注释,完了拷贝下面7条配置到redis.conf文件末尾
port 6379
bind 192.168.1.80
daemonize yes
cluster-enabled yes
cluster-config-file nodes-6379.conf
cluster-node-timeout 15000
pidfile /var/run/redis_6379.pid
克隆5台系统
克隆5台操作系统,并且每台系统的redis.conf中的bind修改成对应的IP
我用的虚拟机,克隆前先关掉虚拟机,即192.168.1.80。不然无法克隆。
打开相关端口
说明:
redis集群不仅需要开通redis客户端连接的端口,而且需要开通集群总线端口
集群总线端口为redis客户端连接的端口 + 10000
如redis端口为6379,则集群总线端口为16379
所以,所有服务器需要开通redis的客户端连接端口和集群总线端口
每台都要开启这两个端口
开启6379端口和16379端口
[root@localhost ~]# firewall-cmd --zone=public --add-port=6379/tcp --permanent
[root@localhost ~]# firewall-cmd --zone=public --add-port=16379/tcp --permanent
重启防火墙
[root@localhost ~]# firewall-cmd --reload
启动redis
每台都要启动
[root@localhost ~]# cd /usr/local/redis/
[root@localhost redis]# src/redis-server redis.conf
启动集群
[root@localhost ~]# /usr/local/redis/src/redis-trib.rb create --replicas 1 192.168.1.80:6379 192.168.1.81:6379 192.168.1.82:6379 192.168.1.83:6379 192.168.1.84:6379 192.168.1.85:6379
如下图,表示成功启动

仔细看这张图,其中
192.168.1.80
192.168.1.81
192.168.1.82
三台节点自动设置成了主节点
192.168.1.83
192.168.1.84
192.168.1.85
三台节点自动设置成了从节点,而且每个从节点对应哪个主节点都有说明。
连接redis集群
在192.168.1.80机器上进行连接
[root@localhost redis]# src/redis-cli -h 192.168.1.80 -c -p 6379
必须要加:-c参数
在192.168.1.80节点上写一条数据,看图:

然后Ctrl+c退出redis客户端,再连接到192.168.1.83节点上进行查询
[root@localhost redis]# src/redis-cli -h 192.168.1.83 -c -p 6379
看图:

看到没,跳转到192.168.1.80上了,从192.168.1.80获取的数据
好了,成功了,累死宝宝了。
参考网址
https://redis.io/download
http://os.51cto.com/art/201702/533052.htm?pc
续
如果重启服务器后,再次执行redis-trib.rb会报错如下错误:
[ERR] Node 192.168.1.80:6379 is not empty. Either the node already knows other nodes (check with CLUSTER NODES) or contains some key in database 0.
解决方法:
删除dump.rdb和nodes-6379.conf这两个文件,然后重启redis服务,最后启动集群。
1次不行搞2次,2次不行搞3次。多删除几次。
centos7安装redis-4.0.1集群的更多相关文章
- CentOS7.2 安装redis 3.0.6集群
1.环境确认 a.系统版本查看 [hadoop@p168 ~]$ cat /etc/redhat-release CentOS Linux release 7.2.1511 (Core) b.安装依 ...
- Redis 5.0.5集群搭建
Redis 5.0.5集群搭建 一.概述 Redis3.0版本之后支持Cluster. 1.1.redis cluster的现状 目前redis支持的cluster特性: 1):节点自动发现 2):s ...
- Redis 3.0 Cluster集群配置
Redis 3.0 Cluster集群配置 安装环境依赖 安装gcc:yum install gcc 安装zlib:yum install zib 安装ruby:yum install ruby 安装 ...
- 配置redis 4.0.11 集群
配置redis 4.0.11 集群 准备redis 软件和redis配置文件 启动Redis服务 /data/soft/redis/src/redis-check-aof --fix /log/red ...
- Centos7下安装redis实战(单机版以及集群)
一.背景 因项目需要,要引入redis做缓存,就在centos7下亲自安装了一遍redis,刚好趁着这个机会就来把redis的概念以及单机版和集群版redis安装步骤记录下来,在此和大家一起分享. 二 ...
- Redis 3.0.2集群搭建以及相关问题汇总
Redis3 正式支持了 cluster,是为了解决构建redis集群时的诸多不便 (1)像操作单个redis一样操作key,不用操心key在哪个节点上(2)在线动态添加.删除redis节点,不用停止 ...
- Redis 5.0.3集群部署
参考文章 https://blog.csdn.net/yyTomson/article/details/85783753 https://www.cnblogs.com/zy-303/p/102731 ...
- redis 3.0的集群部署
转载请注明出处:http://hot66hot.iteye.com/admin/blogs/2050676 最近研究redis-cluster,正好搭建了一个环境,遇到了很多坑,系统的总结下,等到re ...
- (转)redis 3.0的集群部署
一:关于redis cluster 1:redis cluster的现状 reids-cluster计划在redis3.0中推出,可以看作者antirez的声明:http://antirez.com/ ...
- Redis 3.0.5 集群的命令、使用、维护
cluster命令 CLUSTER INFO 打印集群的信息 CLUSTER NODES 列出集群当前已知的所有节点(node),以及这些节点的相关信息. //节点 CLUSTER MEET < ...
随机推荐
- 如何使用vs2012单步调试uGUI(unity3d 5.3f4)
下载uGUI源代码 uGUI源代码地址:https://bitbucket.org/Unity-Technologies/ui 下载代码工具:tortoisehg-3.6.2-x64.msi http ...
- Focal Loss笔记
论文:<Focal Loss for Dense Object Detection> Focal Loss 是何恺明设计的为了解决one-stage目标检测在训练阶段前景类和背景类极度不均 ...
- 【C语言学习笔记】字符串拼接的3种方法 .
昨天晚上和@buptpatriot讨论函数返回指针(malloc生成的)的问题,提到字符串拼接,做个总结. #include<stdio.h> #include<stdlib.h&g ...
- 22 Gobs of data 设计和使用采集数据的包
Gobs of data 24 March 2011 Introduction To transmit a data structure across a network or to store it ...
- 解决insert语句插入时,需要写列值的问题
今天发现解决这个问题其实很简单,闲话不多谈,我直接附上语句 ) select @s = isnull(@s+',', '') + [name] from syscolumns where id = o ...
- Elasticsearch安全问题
本节内容: 背景 修改默认的 Elasticsearch 集群名称 不要暴露 Elasticsearch 在公网上 不要以 root 身份运行 Elasticsearch 定期对 Elasticsea ...
- 【58沈剑架构系列】微服务架构之RPC-client序列化细节
第一章聊了[“为什么要进行服务化,服务化究竟解决什么问题”] 第二章聊了[“微服务的服务粒度选型”] 上一篇聊了[“为什么说要搞定微服务架构,先搞定RPC框架?”] 通过上篇文章的介绍,知道了要实施微 ...
- moment.js笔记
增加日期时间 moment().add(Number, String); moment().add(Duration); moment().add(Object); 添加天数: moment().ad ...
- Java 中byte 与 char 的相互转换 Java基础 但是很重要
char转化为byte: public static byte[] charToByte(char c) { byte[] b = new byte[2]; b[0] = ...
- lr11录制时报“Request Connection: Remote Server @ 0.0.0.0:1080 (Service=?) NOT PROXIED! )”解决方法
在录制脚本的时候出现如下现象: 解决方法: LoadRunner录制脚本时出现:Unable to connect to remote server),有事件没有脚本的问题 1.首先要查看IE浏览 ...