要让集群正常工作至少需要 3 个主节点,在这里我们要创建 6 个 redis 节点,其中三个为主节点,三个为从节点,对应的 redis 节点的 ip 和端口对应关系如下
192.168.2.20:7000
192.168.2.20:7001
192.168. 2.20 :7002
192.168. 2.20 :7003
192.168. 2.20 :7004
192.168. 2.20 :7005
1 :下载 redis 。官网下载 3.0.0 版本,之前 2.x 的版本不支持集群模式
下载地址: http://download.redis.io/releases/redis-3.0.0.tar.gz
2 :上传服务器,解压,编译
tar -zxvf redis-3.0.0.tar.gz
mv redis-3.0.0.tar.gz redis3.0
cd /usr/local/redis3.0
make
make install
3 :创建集群需要的目录(一台机器上模拟6个实例)
mkdir -p /usr/local/cluster
cd /usr/local/cluster
mkdir 7000
mkdir 7001
mkdir 7002
mkdir 7003
mkdir 7004
mkdir 7005
备注: 要让集群正常运作至少需要三个主节点
4 :修改配置文件 redis.conf
cp /usr/local/redis3.0/redis.conf /usr.local/cluster
vi redis.conf
##
修改配置文件中的下面选项
port
7000
daemonize yes
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes
##
修改完
redis.conf
配置文件中的这些配置项之后把这个配置文件分别拷贝到
7000/7001/7002/7003/7004/7005
目录下面
cp /usr/local/cluster/redis.conf /usr/local/cluster/7000
cp /usr/local/cluster/redis.conf /usr/local/cluster/7001
cp /usr/local/cluster/redis.conf /usr/local/cluster/7002
cp /usr/local/cluster/redis.conf /usr/local/cluster/7003
cp /usr/local/cluster/redis.conf /usr/local/cluster/7004
cp /usr/local/cluster/redis.conf /usr/local/cluster/7005
## 注意:拷贝完成之后要修改 7001/7002/7003/7004/7005 目录下面 redis.conf 文件中的 port 参数,分别改为对应的文件夹的名称
5 :分别启动这 6 个 redis 实例
cd /usr/local/cluster/7000
redis-server redis.conf
cd /usr/local/cluster/7001
redis-server redis.conf
cd /usr/local/cluster/7002
redis-server redis.conf
cd /usr/local/cluster/7003
redis-server redis.conf
cd /usr/local/cluster/7004
redis-server redis.conf
cd /usr/local/cluster/7005
redis-server redis.conf
## 启动之后使用命令查看 redis 的启动情况 ps -ef|grep redis
如下图显示则说明启动成功
6 :执行 redis 的创建集群命令创建集群
cd /usr/local/redis3.0/src
./redis-trib.rb create --replicas 1 192.168.2.20:7000 192.168. 2.20 :7001 192.168. 2.20 :7002 192.168. 2.20 :7003 192.168. 2.20 :7004 192.168. 2.20 :7005
注意: replicas 是给master分配slave个数的参数,我们给的参数是1 ,那每个master就有一个从节点.
6.1 执行上面的命令的时候可能会报错,因为是执行的 ruby 的脚本,需要 ruby 的环境
错误内容: /usr/bin/env: ruby: No such file or directory
所以需要安装 ruby 的环境,这里推荐使用 yum install ruby 安装
yum install ruby |
6.2 然后再执行第 6 步的创建集群命令,可能还会报错,提示缺少 rubygems 组件,使用 yum 安装
错误内容:
./redis-trib.rb:24:in `require': no such file to load -- rubygems (LoadError)
from ./redis-trib.rb:24
yum install rubygems |
6.3 再次执行第 6 步的命令,可能还会报错,提示不能加载 redis ,是因为缺少 redis 和 ruby 的接口,使用 gem 安装
错误内容:
/usr/lib/ruby/site_ruby/1.8/rubygems/custom_require.rb:31:in `gem_original_require': no such file to load -- redis (LoadError)
from /usr/lib/ruby/site_ruby/1.8/rubygems/custom_require.rb:31:in `require'
from ./redis-trib.rb:25
gem install redis |
6.4 再次执行第 6 步的命令,正常执行
输入 yes ,然后配置完成。
至此 redis 集群即搭建成功!
7 :使用 redis-cli 命令进入集群环境
redis-cli -c -p 7000 |
备注: -c 表示 cluster模式进入,-p 指定集群某个端口号
登录集群后,然后进行验证:
8:查看集群中的所有节点信息
redis-cli -p 7000 cluster nodes [| grep master]
9: 通过check cluster的一个节点,就知道整个集群的状况
./redis-trib.rb check 192.168.2.20:7000