前言
本文主要是记录一下Redis集群在linux系统下离线的安装步骤,毕竟在生产环境下一般都是无法联网的,Redis的集群的Ruby环境安装过程还是很麻烦的,涉及到很多的依赖的安装,所以写了一个文章来进行记录。本文分为两部分,第一部分先通过原生命令的安装来实现redis集群的部署,通过原生命令的安装对于了解redis集群的实现原理有很大的帮助,第二部分通过官方工具Ruby来进行Redis集群的安装,通过Ruby安装Redis集群的时候主要是搭建好Ruby环境,真正Redis集群的安装配置通过Ruby还是很简单的。
一、通过原生命令安装Redis集群(仅做理解Redis集群原理使用)
1.配置开启所需要的Redis节点
因为这里只是做一个简单的Redis集群原理演示,所以假设此时Redis服务已经安装完毕,在config文件夹下创建六个redis.conf配置文件,分别为redis-7000.conf、redis-7001.conf、redis-7002.conf、redis-7003.conf、redis-7004.conf、redis-7005.conf。其内容如下:
3.指派槽
完成了节点之间的通信以后,就需要给每个主节点分配虚拟槽,一共存在16384个slot,redis节点之间互相知道哪个槽在哪个节点上,如果数据访问到了不属于自己的槽的redis,redis会告诉数据应该去访问哪个redis
指派槽的命令:cluster addslots slot[slot…]
redis-cli -h 127.0.0.1 -p 7000 cluster addslots {0…5641}
redis-cli -h 127.0.0.1 -p 7001 cluster addslots {5642…10922}
redis-cli -h 127.0.0.1 -p 7002 cluster addslots {10923…16383}
在这里发现使用addslots 只能一个一个输入,感觉非常扯,使用数组的方式redis会报错,用网上的解决办法是将大括号里的 三个点改为两个点,我试了试不行的,如果有什么好的解决办法可以提供一下。
4.配置节点的主从关系
cluster replicate node-id
redis-cli -h 127.0.0.1 -p 7003 cluster replicate ${node-id-7000}
redis-cli -h 127.0.0.1 -p 7004 cluster replicate ${node-id-7001}
redis-cli -h 127.0.0.1 -p 7005 cluster replicate ${node-id-7002}
到此通过原生命令安装Redis集群就已经完成了,中间的步骤存在问题,无法分配slots,但是可以帮助简单的理解一下由Redis的单节点到Redis的集群都需要做什么工作。
二、通过Ruby离线安装Redis集群
1.安装环境以及安装包说明
(3)配置redis.conf
cd /usr/local/redis/redis_cluster //进去集群工作目录
vim redis.conf //创建redis.conf文件并添加一下内容

因为配置文件是根据7000端口模本的配置写的,所以除了redis7000目录下的redis.conf,其他工作目录下的配置文件都需要将文件内容中的端口号修改为对应的工作目录的端口号。
(4)启动服务
cd /usr/local/redis/redis_cluster
依次启动所有节点
redis-server redis7000/redis.conf
redis-server redis7001/redis.conf
redis-server redis7002/redis.conf
redis-server redis7003/redis.conf
redis-server redis7004/redis.conf
redis-server redis7005/redis.conf
查看启动情况:ps -ef | grep redis
(5)安装ruby

解决办法:缺少了zlib包,需要安装zlib。
(7)安装zlib

(9)安装redis-3.0.0.gem

因为Redis集群交互是需要OpenSSL,所系我们还需要安装OpenSSL。
(10)安装openssl
(11)编译ruby中的openssl

解决办法:vim Makefile 把Makefile文件中所有的 $(top_srcdir) 换成 ../.. 注意替换所有
替换完成后,重新进行

到这里ruby环境总算是安装成功了,真是不容易啊,其实redis cluster的安装的主要内容还是上面的Ruby环境的安装配置过程。
(12)启动redis集群
输入yes
安装成功:
(13)验证集群状态
以普通方式连接到7002端口的节点 redis-cli -p 7002 -h 192.168.182.132
参数说明: -p port 端口 -h host 主机 -c cluster 集群
连接进集群之后 输入ping , 如果响应了pong 表示连接集群成功;
CLUSTER INFO 列出当前节点的信息,CLUSTER NODES 列出当前集群中的节点信息;

执行命令:set hello word

7002节点报错,客户端该数据应该使用7000端口的客户端才能添加(是因为登录的时候没有加-c)
登录7000端口的客户端重新set hello world,添加数据成功(上次在7002中添加hello world没有成功,所以在7000中获取hello是没有内容的)

使用集群方式连接集群redis-cli -p 7003 -h 192.168.182.132 -c(7003是7000的备机)
查询hello:

重新设置hello的值:

集群信息显示7002节点已经down掉,7005取代7002成为主节点
总结:
虽然整个过程是让人很糟心的,但是总归是成功了,实践出真理。
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。