Redis快速安装之Redis Cluster(3主3从)-CentOS7

Redis快速安装之Redis Cluster(3主3从)-CentOS7

首先,本篇要基于单实例的安装,你的机器上已经有一个Redis

参考地址:https://blog.csdn.net/qq_39938758/article/details/105470165

由于新版的cluster 已经不需要通过ruby脚本创建,所以不演示ruby相关依赖的安装

为了节省机器,我们直接把6个Redis实例安装在同一台机器上(3主3从),只是使用不同的端口号。 机器IP 192.168.170.3

为什么1秒?你可以把下面的步骤包装在脚本里面。这样你可以直接一键执行,如果不会写的伙伴可以联系我。我再写。同时,一秒是创建脚本的时间。。。。 因为我单身,所以创建脚本copy快。。。

1、第一步:创建配置
cd /usr/local/soft/redis-5.0.5
mkdir redis-cluster
cd redis-cluster
mkdir 7291 7292 7293 7294 7295 7296
  • 打开防火墙(如果需要)
firewall-cmd --add-port=6379/tcp --permanent
firewall-cmd --add-port=7291/tcp --permanent
firewall-cmd --add-port=7292/tcp --permanent
firewall-cmd --add-port=7293/tcp --permanent
firewall-cmd --add-port=7294/tcp --permanent
firewall-cmd --add-port=7295/tcp --permanent
firewall-cmd --add-port=7296/tcp --permanent
firewall-cmd --reload
2、复制redis配置文件到7291目录
cp /usr/local/soft/redis-5.0.5/redis.conf /usr/local/soft/redis-5.0.5/redis-cluster/7291
3、修改7291的redis.conf配置文件成为base配置文件
cd /usr/local/soft/redis-5.0.5/redis-cluster/7291
vi redis.conf
# 修改配置中的如下参数
port 7291
daemonize yes
protected-mode no
dir "/usr/local/soft/redis-5.0.5/redis-cluster/7291/"
cluster-enabled yes
cluster-config-file nodes-7291.conf
cluster-node-timeout 5000
appendonly yes
pidfile /var/run/redis_7291.pid
bind 0.0.0.0
4、把base配置redis.conf复制到其他5个目录。
cd /usr/local/soft/redis-5.0.5/redis-cluster/7291
cp redis.conf ../7292
cp redis.conf ../7293
cp redis.conf ../7294
cp redis.conf ../7295
cp redis.conf ../7296 
5、sed命令批量替换内容
cd /usr/local/soft/redis-5.0.5/redis-cluster
sed -i 's/7291/7292/g' 7292/redis.conf
sed -i 's/7291/7293/g' 7293/redis.conf
sed -i 's/7291/7294/g' 7294/redis.conf
sed -i 's/7291/7295/g' 7295/redis.conf
sed -i 's/7291/7296/g' 7296/redis.conf
6、启动6个Redis节点
cd /usr/local/soft/redis-5.0.5/
./src/redis-server redis-cluster/7291/redis.conf
./src/redis-server redis-cluster/7292/redis.conf
./src/redis-server redis-cluster/7293/redis.conf
./src/redis-server redis-cluster/7294/redis.conf
./src/redis-server redis-cluster/7295/redis.conf
./src/redis-server redis-cluster/7296/redis.conf
7、是否启动了6个进程
ps -ef|grep redis
8、创建集群

旧版本中的redis-trib.rb已经废弃了,直接用–cluster命令
注意用绝对IP,不要用127.0.0.1

cd /usr/local/soft/redis-5.0.5/src/
redis-cli --cluster create 192.168.170.3:7291 192.168.170.3:7292 192.168.170.3:7293 192.168.170.3:7294 192.168.170.3:7295 192.168.170.3:7296 --cluster-replicas 1
  • Redis会给出一个预计的方案,对6个节点分配3主3从,如果认为没有问题,输入yes确认
>>> Performing hash slots allocation on 6 nodes...
Master[0] -> Slots 0 - 5460
Master[1] -> Slots 5461 - 10922
Master[2] -> Slots 10923 - 16383
Adding replica 192.168.170.3:7295 to 192.168.170.3:7291
Adding replica 192.168.170.3:7296 to 192.168.170.3:7292
Adding replica 192.168.170.3:7294 to 192.168.170.3:7293
>>> Trying to optimize slaves allocation for anti-affinity
[WARNING] Some slaves are in the same host as their master
M: 24e9ec7694cd9e55d98c5634755cb7fec37c369c 192.168.170.3:7291
   slots:[0-5460] (5461 slots) master
M: 8e5ffa5bb457571f66b5567c2baa45717d2c3967 192.168.170.3:7292
   slots:[5461-10922] (5462 slots) master
M: 01129adc755316b38e2fc474b6d2c71443d89247 192.168.170.3:7293
   slots:[10923-16383] (5461 slots) master
S: cdaa02c0b43ded5a7f9ff5576bec4d7a6076bb99 192.168.170.3:7294
   replicates 24e9ec7694cd9e55d98c5634755cb7fec37c369c
S: 5e543eb3b9581a0298ed3264371a9c5cbc7c6057 192.168.170.3:7295
   replicates 8e5ffa5bb457571f66b5567c2baa45717d2c3967
S: 2b7e11f7bf8c2b27c07c104d8081476abc6ec0dd 192.168.170.3:7296
   replicates 01129adc755316b38e2fc474b6d2c71443d89247
Can I set the above configuration? (type 'yes' to accept): 
  • 注意看slot的分布:
7291  [0-5460] (5461个槽) 
7292  [5461-10922] (5462个槽) 
7293  [10923-16383] (5461个槽)
  • 集群创建完成
>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join
...
>>> Performing Cluster Check (using node 192.168.170.3:7291)
M: 24e9ec7694cd9e55d98c5634755cb7fec37c369c 192.168.170.3:7291
   slots:[0-5460] (5461 slots) master
   1 additional replica(s)
S: cdaa02c0b43ded5a7f9ff5576bec4d7a6076bb99 192.168.170.3:7294
   slots: (0 slots) slave
   replicates 24e9ec7694cd9e55d98c5634755cb7fec37c369c
S: 2b7e11f7bf8c2b27c07c104d8081476abc6ec0dd 192.168.170.3:7296
   slots: (0 slots) slave
   replicates 01129adc755316b38e2fc474b6d2c71443d89247
S: 5e543eb3b9581a0298ed3264371a9c5cbc7c6057 192.168.170.3:7295
   slots: (0 slots) slave
   replicates 8e5ffa5bb457571f66b5567c2baa45717d2c3967
M: 8e5ffa5bb457571f66b5567c2baa45717d2c3967 192.168.170.3:7292
   slots:[5461-10922] (5462 slots) master
   1 additional replica(s)
M: 01129adc755316b38e2fc474b6d2c71443d89247 192.168.170.3:7293
   slots:[10923-16383] (5461 slots) master
   1 additional replica(s)
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
  • 重置集群的方式是在每个节点上个执行cluster reset,然后重新创建集群

    连接到客户端

redis-cli -p 7291
redis-cli -p 7292
redis-cli -p 7293
9、集群测试
  • 批量写入值脚本创建
cd /usr/local/soft/redis-5.0.5/redis-cluster/
vim setkey.sh
  • 脚本内容
# 脚本内容
#!/bin/bash
for ((i=0;i<20000;i++))
do
echo -en "helloworld" | redis-cli -h 192.168.8.207 -p 7291 -c -x set name$i >>redis.log
done
  • 设置脚本权限并执行
chmod +x setkey.sh
./setkey.sh
  • 验证分布情况
127.0.0.1:7292> dbsize
(integer) 6683
127.0.0.1:7293> dbsize
(integer) 6665
127.0.0.1:7291> dbsize
(integer) 6652

其他命令

redis-cli --cluster help
Cluster Manager Commands:
  create         host1:port1 ... hostN:portN
                 --cluster-replicas <arg>
  check          host:port
                 --cluster-search-multiple-owners
  info           host:port
  fix            host:port
                 --cluster-search-multiple-owners
  reshard        host:port
                 --cluster-from <arg>
                 --cluster-to <arg>
                 --cluster-slots <arg>
                 --cluster-yes
                 --cluster-timeout <arg>
                 --cluster-pipeline <arg>
                 --cluster-replace
  rebalance      host:port
                 --cluster-weight <node1=w1...nodeN=wN>
                 --cluster-use-empty-masters
                 --cluster-timeout <arg>
                 --cluster-simulate
                 --cluster-pipeline <arg>
                 --cluster-threshold <arg>
                 --cluster-replace
  add-node       new_host:new_port existing_host:existing_port
                 --cluster-slave
                 --cluster-master-id <arg>
  del-node       host:port node_id
  call           host:port command arg arg .. arg
  set-timeout    host:port milliseconds
  import         host:port
                 --cluster-from <arg>
                 --cluster-copy
                 --cluster-replace
  help           

For check, fix, reshard, del-node, set-timeout you can specify the host and port of any working node in the cluster.

附录:

集群命令

cluster info :打印集群的信息
cluster nodes :列出集群当前已知的所有节点(node),以及这些节点的相关信息。
cluster meet :将 ip 和 port 所指定的节点添加到集群当中,让它成为集群的一份子。
cluster forget <node_id> :从集群中移除 node_id 指定的节点(保证空槽道)。
cluster replicate <node_id> :将当前节点设置为 node_id 指定的节点的从节点。
cluster saveconfig :将节点的配置文件保存到硬盘里面。

槽slot命令

cluster addslots [slot …] :将一个或多个槽(slot)指派(assign)给当前节点。
cluster delslots [slot …] :移除一个或多个槽对当前节点的指派。
cluster flushslots :移除指派给当前节点的所有槽,让当前节点变成一个没有指派任何槽的节点。
cluster setslot node <node_id> :将槽 slot 指派给 node_id 指定的节点,如果槽已经指派给另一个节点,那么先让另一个节点删除该槽>,然后再进行指派。
cluster setslot migrating <node_id> :将本节点的槽 slot 迁移到 node_id 指定的节点中。
cluster setslot importing <node_id> :从 node_id 指定的节点中导入槽 slot 到本节点。
cluster setslot stable :取消对槽 slot 的导入(import)或者迁移(migrate)。

键命令

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值