集群环境:CenterOs7以及redis-3.2.9.tar.gz,由于电脑性能限制,只能通过创建6个文件夹来模拟Redis集群,端口号分别为:
7001,7002,7003,7004,7005,7006.
本次集群至少要三个master,我们切换到/usr/local目录下创建一个redis-cluster.
cd /usr/local
mkdir redis-cluster
在redis-cluster目录下创建6个目录,分别为7001,7002,7003,7004,7005,7006
mkdir 7001
mkdir 7002
mkdir 7003
mkdir 7004
mkdir 7005
mkdir 7006
切换到我们存放redis安装包的目录下,将解压之后的文件解压到/usr/local/目录下
tar -zxvf redis-3.2.9.tar.gz -c /usr/local
切换到redis的根木录下,安装gcc
cd /usr/local/redis-3.2.9
yum install gcc
执行编译安装:
进入到redis目录,执行make
进入到src目录,执行make install/make test
建立两个文件夹存放redis命令和配置文件
mkdir -p /usr/local/redis-cluster/7001/etc
mkdir -p /usr/local/redis-cluster/7001/bin
进入到安装目录中的redis目录下,将redis.conf 复制到/usr/local/redis-cluster/7001/etc/目录下
cp redis.conf /usr/local/redis-cluster/7001/etc/
切换到bin目录下:将 mkreleasehdr.sh redis-benchmark redis-check-aof redis-cli redis-server 文件移动到/usr/local/redis-cluster/7001/bin目录下
mv mkreleasehdr.sh redis-benchmark redis-check-aof redis-cli redis-server /usr/local/redis-cluster/7001/bin
修改/usr/local/redis-cluster/7001/etc/redis.conf配置文件:
daemonize yes
port 7001
bind 192.168.195.136(绑定的是你做集群的当前机器)
dir /usr/local/redis-cluster/7001/ (指定数据存放,必须要指定不同的目录位置,不然会丢失数据)
cluster-enabled yes 开启集群
cluster-config-file nodes7001.conf
appendonly yes
修改pidfile文件路径
修改完之后退出保存
将7001/etc/redis/conf拷贝到7002,7003,7004,7005,7006下的etc目录
在命令编辑模式下替换响应的端口号:%s /7001/700x/g
由于redis集群需要使用ruby命令,所以我们需要安装ruby,但是我们直接通过yum install ruby -y命令是安装不了。
所以我们可以通过先安装RVM,其实很多不懂linux的人不知道yum是干嘛什么的,其实他是通过网络直接下载安装包,进行安装。所以这时候你可以检查你的网络是否给外网进行联通。可以ping www.baidu.com来检查
yum install centos-release-scl-rh
安装完RVM之后,我们再来安装ruby
yum install rh-ruby23 -y
scl enable rh-ruby23 bash
通过ruby -v来查看ruby的版本
安装redis和ruby的接口
gem install redis
分别启动6个redis.然后检查是否启动成功
/usr/local/redis/bin/redis-server /usr/local/redis-cluster/700x/etc/redis.conf x是指你要启动哪一台redis
到redis3.2.9的安装目录下,然后执行redis-trib.rb命令
cd /usr/local/redis-3.2.9/src
./redis-trib.rb create --replicas 1 192.168.195.136:7001 192.168.195.136:7002 192.168.195.136:7003 192.168.195.136:7004 192.168.195.136:7005 192.168.195.136:7006
(这里面的1 表示的是主从的比值.)
这样集群成功,