Centos7 上部署 redis集群


先看一下 Redis 5 带来的更新内容:将 Lua 脚本更好地传播到 replicas / AOFLua 脚本现在可以超时并在副本中进入 -BUSY 状态Redis 5 是 Redis 引入流数据类型(Stream data type)的第一个版本。按照官方的说法,不使用该特性的用户在生产环境中使用 Redis 5 会有更好的体验 —— 虽然开发团队尚未发现关于这项特性的关键错误。此外,因为许多内部结构与 Redis 4 共享,因此在内部工作方式方面,变化不会很大。详细更新内容请查看:https://raw.githubusercontent.com/antirez/redis/5.0/00-RELEASENOTES二、安装redis部分
1、环境
linux系统 centos 7.6版本
redis: redis5.0.5的 statble版本(redis-stable.tar.gz)
2、下载解压安装
#下载
wget http://download.redis.io/releases/redis-stable.tar.gz#解压
tar xzf redis-stable.tar.gz#进入解压文件
cd redis-stable#编译源码
make install#测试是否安装成功

启动成功表示安装成功
上面只是一个临时的启动文件,需要一直连接需要改配置文件,顺便集群的配置也一起设置了。2、配置redis cluster集群
redis集群可以参考官网给出的教程https://redis.io/topics/cluster-tutorial首先要复制多分redis.conf文件,修改以下配置,注意将端口号区分开cat /data/redis-cluster/cluster-conf/7000/redis.conf | grep -v ‘#’只贴出部分差异配置,其他的都用系统默认的,有需要自行更改。
配置里有不同目录的自行创建, 也可以根据你自己想要求更改不同路径下的。bind 127.0.0.1
port 7000
pidfile /var/run/redis_7000.pid
logfile “/data/redis-cluster/redis-log/redis_7000.log”
dbfilename dump_7000.rdb
dir /data/redis-cluster/rdb/
appendonly yesappendfilename “appendonly_7000.aof”
appendfsync everysecmkdir -p /data/redis-cluster/cluster-conf
cd /data/redis-cluster/cluster-conf
mkdir 7000 7001 7002 7003 7004 7005
#先根据上面的配置修改一份7000/redis.conf的配置,初始的文件从redis-stable/src/redis.conf复制一份来做修改。然后/data/redis-cluster/cluster-conf/7000/redis.conf的配置复制一份并替换不同端口目录下的配置文件cp /data/redis-cluster/cluster-conf/7000/redis.conf /data/redis-cluster/cluster-conf/7001/redis.conf cp /data/redis-cluster/cluster-conf/7000/redis.conf /data/redis-cluster/cluster-conf/7002/redis.conf cp /data/redis-cluster/cluster-conf/7000/redis.conf /data/redis-cluster/cluster-conf/7003/redis.conf cp /data/redis-cluster/cluster-conf/7000/redis.conf /data/redis-cluster/cluster-conf/7004/redis.conf cp /data/redis-cluster/cluster-conf/7000/redis.conf /data/redis-cluster/cluster-conf/7005/redis.conf 然后再将对应的配置文件放入进去后 启动每个服务
/usr/local/bin/redis-server /data/redis-cluster/cluster-conf/7000/redis.conf
/usr/local/bin/redis-server /data/redis-cluster/cluster-conf/7001/redis.conf
/usr/local/bin/redis-server /data/redis-cluster/cluster-conf/7002/redis.conf
/usr/开发云主机域名local/bin/redis-server /data/redis-cluster/cluster-conf/7003/redis.conf
/usr/local/bin/redis-server /data/redis-cluster/cluster-conf/7004/redis.conf
/usr/local/bin/redis-server /data/redis-cluster/cluster-conf/7005/redis.conf#7000-7005服务启动成功后,使用5.0特有的redis-cli功能开启集群
/usr/local/bin/redis-cli –cluster create 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 –cluster-replicas 1
这样集群就起来了。为了方便启动,可以放一个脚本里启动。如下脚本
[root@VM_0_6_centos src]# cat /data/redis-cluster/cluster-conf/start_all.sh
#!/bin/bash
/usr/local/bin/redis-server /data/redis-cluster/cluster-conf/7000/redis.conf
/usr/local/bin/redis-server /data/redis-cluster/cluster-conf/7001/redis.conf
/usr/local/bin/redis-server /data/redis-cluster/cluster-conf/7002/redis.conf
/usr/local/bin/redis-server /data/redis-cluster/cluster-conf/7003/redis.conf
/usr/local/bin/redis-server /data/redis-cluster/cluster-conf/7004/redis.conf
/usr/local/bin/redis-server /data/redis-cluster/cluster-conf/7005/redis.conf/usr/local/bin/redis-cli –cluster create 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 –cluster-replicas 1
到这里就启动了redis集群三、查看且添加新集群相关命令参考:https://redis.io/topics/cluster-tutorial
1、查看集群里的master是哪些
redis-cli -p 7000 cluster nodes | grep master
2、查看集群哪些是slave
redis-cli -p 7000 cluster nodes | grep slave
3、查看哪些对应connected
redis-cli -p 7000 cluster nodes | grep myself
redis-cli -p 7001 cluster nodes | grep myself
redis-cli -p 7002 cluster nodes | grep myself4、添加新的master和slave
先创建两个服务7006 7007的, 具体文件配置参考上面的7000-7005的
配置好对应的文件后用命令启动
/usr/local/bin/redis-server /data/redis-cluster/cluster-conf/7006/redis.conf
/usr/local/bin/redis-server /data/redis-cluster/cluster-conf/7007/redis.conf因为上面启动没有加入到集群里,需要通过集群命令进行加入
加入集群命令
redis-cli –cluster add-node 127.0.0.1:7006 127.0.0.1:7000另外一个新添加的slave也要加入对应的master上
#自动匹配空闲的 加入到对应的master上
redis-cli –cluster add-node 127.0.0.1:7006 127.0.0.1:7000 –cluster-slave或者根据指定的master ID 匹配上
#set master
#redis-cli –cluster add-node 127.0.0.1:7006 127.0.0.1:7000 –cluster-slave –cluster-master-id e508a26956ca359d1917cfd1f3dbb9a9fdd8c28f—e508a26956ca359d1917cfd1f3dbb9a9fdd8c28f 通过redis-cli -p 7000 cluster nodes | grep master 可查看到对应7006的master id.四、重启集群和重建集群
重启:
(保留原有集群的)重启:
不需要再执行(如/usr/local/bin/redis-cli -a ‘Good’ –cluster create 172.17.0.6:7000 172.17.0.6:7001 172.17.0.6:7002 172.17.0.6:7003 172.17.0.6:7004 172.17.0.6:7005 172.17.0.6:7006 172.17.0.6:7007 –cluster-replicas 1这样的)集群生成指令。第一步:先关闭各个Redis节点。第二步:再启动各个Redis节点即可。(删除原有集群的)重启:
需要执行(如/usr/local/bin/redis-cli -a ‘Good’ –cluster create 172.17.0.6:7000 172.17.0.6:7001 172.17.0.6:7002 172.17.0.6:7003 172.17.0.6:7004 172.17.0.6:7005 172.17.0.6:7006 172.17.0.6:7007 –cluster-replicas 1这样的)集群生成指令。第一步:先关闭各个Redis节点。第二步:删除各个Redis安装目录下的节点配置文件nodes.conf、数据文件dump.rdb。说明:此方式相当于重置到刚刚创建集群的时候了,所以需要删除节点配置文件nodes.conf、还需
要删除数据存储文件dump.rdb。五、Cluster相关的命令,现在对所有的命令所以下说明。 CLUSTER info:打印集群的信息。
CLUSTER nodes:列出集群当前已知的所有节点(node)的相关信息。
CLUSTER meet :将ip和port所指定的节点添加到集群当中。
CLUSTER addslots [slot …]:将一个或多个槽(slot)指派(assign)给当前节点。
CLUSTER delslots [slot …]:移除一个或多个槽对当前节点的指派。
CLUSTER slots:列出槽位、节点信息。
CLUSTER slaves :列出指定节点下面的从节点信息。
CLUSTER replicate :将当前节点设置为指定节点的从节点。
CLUSTER saveconfig:手动执行命令保存保存集群的配置文件,集群默认在配置修改的时候会自动保存配置文件。
CLUSTER keyslot :列出key被放置在哪个槽上。
CLUSTER flushslots:移除指派给当前节点的所有槽,让当前节点变成一个没有指派任何槽的节点。
CLUSTER countkeysinslot :返回槽目前包含的键值对数量。
CLUSTER getkeysinslot :返回count个槽中的键。
CLUSTER setslot node 将槽指派给指定的节点,如果槽已经指派给另一个节点,那么先让另一个节点删除该槽,然后再进行指派。
CLUSTER setslot migrating 将本节点的槽迁移到指定的节点中。
CLUSTER setslot importing 从 node_id 指定的节点中导入槽 slot 到本节点。
CLUSTER setslot stable 取消对槽 slot 的导入(import)或者迁移(migrate)。
CLUSTER failover:手动进行故障转移。
CLUSTER forget :从集群中移除指定的节点,这样就无法完成握手,过期时为60s,60s后两节点又会继续完成握手。
CLUSTER reset [HARD|SOFT]:重置集群信息,soft是清空其他节点的信息,但不修改自己的id,hard还会修改自己的id,不传该参数则使用soft方式。
CLUSTER count-failure-reports :列出某个节点的故障报告的长度。
CLUSTER SET-CONFIG-EPOCH:设置节点epoch,只有在节点加入集群前才能设置。
其他参考文章链接:
Redis-5.0.0集群配置
https://www.cnblogs.com/aquester/p/9891465.htmlredis学习之集群报错Node is not empty
https://blog.csdn.net/wudalang_gd/article/details/52153571redis初试Not all 16384 slots are covered by nodes
https://www.cnblogs.com/dupang/p/5631007.htmlRedis Cluster部署、管理和测试
https://www.cnblogs.com/zhoujinyi/p/6477133.html参考:https://blog.csdn.net/justry_deng/article/details/89205155

相关推荐: 来来来!游戏场景风格暴露你的年纪

大家是不是不知道什么是低多边形风格游戏呢,唉,还是太年轻啊。记得当年极为火热暗黑破坏神、红色警戒、塞尔达传说等等经典游戏都可以归为低多边形风格游戏。当然了,当年的主要问题却是电脑配置跟不上了。随着电脑硬件的逐渐升级,游戏画面的精度却是越来越高,低多边形游戏也就…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 03/30 08:35
下一篇 03/30 08:35