说明:单体Redis有许多问题,可通过Redis数据持久化、搭建主从集群、哨兵和Redis分片集群解决单体Redis数据丢失、高并发、数据恢复和海量数据存储的问题。前三个参考http://t.csdn.cn/6pp2F、http://t.csdn.cn/o9u0S,本问介绍如何创建Redis分片集群。
结构图
创建
如上图所示,创建六个Redis实例,三个master(端口分别为:7001、7002、7003),三个slave(端口分别为:8001、8002、8003)
第一步:创建目录
切换到/tmp/essay目录下,创建六个文件夹,文件夹名为端口号
mkdir 7001 7002 7003 8001 8002 8003
第二步:创建配置文件
在当前目录下创建redis.conf文件,内容如下,注意需要修改对应的IP地址和路径
port 6379
# 开启集群功能
cluster-enabled yes
# 集群的配置文件名称,不需要我们创建,由redis自己维护
cluster-config-file /tmp/essay/6379/nodes.conf
# 节点心跳失败的超时时间
cluster-node-timeout 5000
# 持久化文件存放目录
dir /tmp/essay/6379
# 绑定地址
bind 0.0.0.0
# 让redis后台运行
daemonize yes
# 注册的实例ip
replica-announce-ip IP地址
# 保护模式
protected-mode no
# 数据库数量
databases 1
# 日志
logfile /tmp/essay/6379/run.log
第三步:拷贝配置文件
将配置文件拷贝到各个目录下
echo 7001 7002 7003 8001 8002 8003 | xargs -t -n 1 cp redis.conf
第四步:修改对应配置
将各个文件夹内配置内容中的6379修改为对应的端口;
printf '%s\n' 7001 7002 7003 8001 8002 8003 | xargs -I{} -t sed -i 's/6379/{}/g' {}/redis.conf
第五步:启动
启动所有redis
printf '%s\n' 7001 7002 7003 8001 8002 8003 | xargs -I{} -t redis-server {}/redis.conf
查看进程状态,可以看到redis服务已经全部打开
第六步:集群关联
输入以下命令(需要redis5.0以后才可以),建立关系,7001-7003为master,8001-8003为前面对应的slave;
redis-cli --cluster create --cluster-replicas 1 IP地址:7001 IP地址:7002 IP地址:7003 IP地址:8001 IP地址:8002 IP地址:8003
敲“yes”,继续
完成
第七步:测试
输入下面的命令,查看集群状态
redis-cli -p 7001 cluster nodes
可以看到分片集群已经搭建成功,master节点后面有卡槽范围,一个节点分别有5461个卡槽
进入7001Redis客户端操作,需要注意集群操作需要加-c
redis-cli -c -p 7001
随便添加两个值,可以看到前面的端口号发生了变化,说明数据随机存储在三个master对应的卡槽中,这样就解决了海量数据的存储问题。
总结
通过搭建Redis分片集群,可解决单机Redis的海量数据存储问题。另外,Redis分片集群是Redis集群演变的最终形态,Redis分片集群同样具备主从集群结构、Redis哨兵结构所拥有的优点,就是说Redis分片集群可以完全解决Redis单机的“四大问题”。