#mkdir cluster-test
#cd cluster-test
#mkdir 7000 7001 7002 7003 7004 7005
在每个文件夹 #touch redis.conf
redis.conf
bind 127.0.0.1 //绑定服务器IP地址
port 7000 //绑定端口号,必须修改,以此来区分Redis实例
daemonize yes //后台运行
pidfile /var/run/redis-7000.pid //修改pid进程文件名,以端口号命名
logfile /root/application/program/redis-cluster/7000/redis.log //修改日志文件名称,以端口号为目录来区分
dir /root/application/program/redis-cluster/7000/ //修改数据文件存放地址,以端口号为目录名来区分
cluster-enabled yes //启用集群
cluster-config-file nodes-7000.conf //配置每个节点的配置文件,同样以端口号为名称
cluster-node-timeout 15000 //配置集群节点的超时时间,可改可不改
appendonly yes //启动AOF增量持久化策略
appendfsync always //发生改变就记录日志
下载redis包:
$ wget http://download.redis.io/releases/redis-4.0.11.tar.gz
$ tar xzf redis-4.0.11.tar.gz
$ cd redis-4.0.11
$ make
cp redis-server …/cluster-test
cp redis-cli ,/cluster-test
cp redis-trib.rb …/cluster-test
//安装ruby
yum install ruby //安装ruby
yum install rubygems //安装rubygems,最新版本会自动安装
gem install redis -v 3.3.3
启动每个redis节点(进入7000-7005目录)
…/redis-server ./redis.conf
#ps -ef|grep redis
说明启动成功
搭建集群:
redis-trib.rb create --replicas 1 127.0.0.1:7000 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
执行:
说明搭建成功:
可能出现问题:
说明槽被占用
处理:
进入每个节点客户端
./redis-cli -p 7000
127.0.0.1>flushall
ok
127.0.0.1>keys *
empty
127.0.0.1>cluster reset
ok
在执行 redis-trib.rb create --replicas 1 127.0.0.1:7000 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
可成功
使用redis集群 进入客户端
./redis-cli -c -p 7000
可以执行 get set等等操作