Redis-Cluster集群Linux服务器搭建部署(redis5.0x以上的)

Redis单机版,小伙伴们可以看我之前的文章:
https://blog.csdn.net/Mak1214/article/details/86625167

将redis压缩包上传到/usr/local/redis
Redis-Cluster集群Linux服务器搭建部署(redis5.0x以上的)_第1张图片
进行解压缩
tar -zxvf redis-5.0.1.tar.gz(图略)
压缩后进入redis-5.0.1目录下执行
make (图略)
安装redis到/usr/local/redis目录下

make install PREFIX=/usr/local/redis

复制redis.conf到/usr/local/redis下

cp redis-5.0.1/redis.conf .

Redis-Cluster集群Linux服务器搭建部署(redis5.0x以上的)_第2张图片
再/usr/local/redis下创建一个redis-cluster文件夹
mkdir redis-cluster(图略)
进入redis-cluster文件夹并创建6380 6381 6382 6383 6384 6385 六个子文件夹
进入: cd redis-cluster
创建: mkdir 6380 6381 6382 6383 6384 6385
Redis-Cluster集群Linux服务器搭建部署(redis5.0x以上的)_第3张图片
复制redis.conf文件到其中一个子文件夹(6380)下:

cp redis.conf 6380

修改6380下得redis.conf

     bin 127.0.0.1注释掉
     port  6380
     protected-mode yes   将yes该为no,yes是保护模式不允许其他地址ip地址访问
     daemonize no 将no改为yes ,Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程
     pidfile /var/run/redis_6380.pid   修改端口为6380
     logfile ""   修改为:logfile "/usr/local/redis/redis-cluster/6380/redis.log"  存放log日志的目录
     dir ./ 修改为/usr/local/redis/redis-cluster/6380/   修改数据文件存放地址
     appendonly no 将no改为yes 
     appendfsync always
 #appendfsync everysec
 # appendfsync no  
     cluster-enabled yes 放开注释  启用集群
     cluster-config-file nodes-6380.conf 
     cluster-node-timeout 15000

将文件夹下的redis.conf(/cluster-redis/6380/redis.conf)分别复制到/cluster-redis/6381 /cluster-redis/6382 /cluster-redis/6383 /cluster-redis/6384 /cluster-redis/6385
命令 进入cd cluster-redis目录下(记得复制后修改里面内容将6380分别改为其他五个)

cp 6380/redis.conf  6381
cp 6380/redis.conf  6382
cp 6380/redis.conf  6383
cp 6380/redis.conf  6384
cp 6380/redis.conf  6385

启动redis服务端命令

/usr/local/redis/bin/redis-server /usr/local/redis/redis-cluster/6380/redis.conf
/usr/local/redis/bin/redis-server /usr/local/redis/redis-cluster/6381/redis.conf
/usr/local/redis/bin/redis-server /usr/local/redis/redis-cluster/6382/redis.conf
/usr/local/redis/bin/redis-server /usr/local/redis/redis-cluster/6383/redis.conf
/usr/local/redis/bin/redis-server /usr/local/redis/redis-cluster/6384/redis.conf
/usr/local/redis/bin/redis-server /usr/local/redis/redis-cluster/6385/redis.conf

启动redis客户端命令集群模式

./redis-cli  --cluster  create   192.168.32.129:6385 192.168.32.129:6384 192.168.32.129:6383 192.168.32.129:6382 192.168.32.129:6381 192.168.32.129:6380 --cluster-replicas 1

Redis-Cluster集群Linux服务器搭建部署(redis5.0x以上的)_第4张图片
输入yes:
Redis-Cluster集群Linux服务器搭建部署(redis5.0x以上的)_第5张图片

测试一下(不同节点的存取):

/usr/local/redis/bin/redis-cli -h 192.168.32.129 -p 6380 -c

在6380存,6384取值
例子:

set name mayankun 
get name 

Redis-Cluster集群Linux服务器搭建部署(redis5.0x以上的)_第6张图片
也可以测试主从切换:
现任意将一个节点宕掉,再重新启动;
Redis-Cluster集群Linux服务器搭建部署(redis5.0x以上的)_第7张图片
重启节点后查看是否切换成功:

cluster nodes

Redis-Cluster集群Linux服务器搭建部署(redis5.0x以上的)_第8张图片
开放端口

firewall -cmd -permanent --add -prot=6379/tcp

修改配置文件/etc/sysconfig/iptables.config开放端口

-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 6379 -j ACCEPT

关闭防火墙systemctl stop firewalld
开启防火墙 systemctl start firewalld
查看防火墙状态systemctl status firewalld
三、集群客户端命令(redis-cli -c -p port)
转载连接:
https://www.cnblogs.com/gossip/p/5993922.html
集群
cluster info :打印集群的信息
cluster nodes :列出集群当前已知的所有节点( node),以及这些节点的相关信息。
节点
cluster meet :将 ip 和 port 所指定的节点添加到集群当中,让它成为集群的一份子。
cluster forget :从集群中移除 node_id 指定的节点。
cluster replicate :将当前节点设置为 node_id 指定的节点的从节点。
cluster saveconfig :将节点的配置文件保存到硬盘里面。
槽(slot)
cluster addslots [slot …] :将一个或多个槽( slot)指派( assign)给当前节点。
cluster delslots [slot …] :移除一个或多个槽对当前节点的指派。
cluster flushslots :移除指派给当前节点的所有槽,让当前节点变成一个没有指派任何槽的节点。
cluster setslot node :将槽 slot 指派给 node_id 指定的节点,如果槽已经指派给
另一个节点,那么先让另一个节点删除该槽>,然后再进行指派。
cluster setslot migrating :将本节点的槽 slot 迁移到 node_id 指定的节点中。
cluster setslot importing :从 node_id 指定的节点中导入槽 slot 到本节点。
cluster setslot stable :取消对槽 slot 的导入( import)或者迁移( migrate)。

cluster keyslot :计算键 key 应该被放置在哪个槽上。
cluster countkeysinslot :返回槽 slot 目前包含的键值对数量。
cluster getkeysinslot :返回 count 个 slot 槽中的键

写的不好的地方,请指出来哦!!!

你可能感兴趣的:(热血,女屌丝)