首页 > 数据库 >三主三从的redis集群迁移数据到单节点redis上的操作步骤

三主三从的redis集群迁移数据到单节点redis上的操作步骤

时间:2023-02-21 15:34:34浏览次数:44  
标签:node 三主三 redis 192.168 6379 0.164 操作步骤 节点

1.查看redis集群信息

[root@database01 ~]# redis-cli -c -h 192.168.0.164 -p 6379
192.168.0.164:6379> auth c2b9d063b86153fd9436fb07d8b3801d9ea40629964c422a22aac5a9eb9af3a1
OK
192.168.0.164:6379> cluster nodes
205e88f0a5984698c09328d1a1b16fd273eb79f2 192.168.0.39:6380@16380 slave 5a308d09f6372ff8a361c0e074c9f57d783dc9c6 0 1676961626000 5 connected
abb2ab96ce5f65d0bc4362aa775274c8090be2af 192.168.0.164:6380@16380 master - 0 1676961627450 7 connected 10923-16383
a745e59c190f629d04905550f341d67dea47758f 192.168.0.39:6379@16379 master - 0 1676961626000 2 connected 5461-10922
5a308d09f6372ff8a361c0e074c9f57d783dc9c6 192.168.0.164:6379@16379 myself,master - 0 1676961627000 1 connected 0-5460
1bdcabe88cface91c23b91c9e92db33e6dde02d1 192.168.0.68:6380@16380 slave a745e59c190f629d04905550f341d67dea47758f 0 1676961626448 6 connected
7c369ee5e691a94e141e0ba44ee86f47d6cbd469 192.168.0.68:6379@16379 slave abb2ab96ce5f65d0bc4362aa775274c8090be2af 0 1676961626000 7 connected

2.关闭redis集群中的三个从节点

可以同时开两个窗口,一个窗口执行命令操作,另一个创建查看集群节点数等

# 命令格式:redis-cli --cluster del-node 节点ip:port 节点ID -a '集群访问密码'

# redis-cli --cluster del-node 192.168.0.39:6380 205e88f0a5984698c09328d1a1b16fd273eb79f2 -a 'c2b9d063b86153fd9436fb07d8b3801d9ea40629964c422a22aac5a9eb9af3a1'
Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.
>>> Removing node 205e88f0a5984698c09328d1a1b16fd273eb79f2 from cluster 192.168.0.39:6380
>>> Sending CLUSTER FORGET messages to the cluster...
>>> SHUTDOWN the node.

redis-cli --cluster del-node 192.168.0.68:6379 7c369ee5e691a94e141e0ba44ee86f47d6cbd469 -a 'c2b9d063b86153fd9436fb07d8b3801d9ea40629964c422a22aac5a9eb9af3a1'
redis-cli --cluster del-node 192.168.0.68:6380 1bdcabe88cface91c23b91c9e92db33e6dde02d1 -a 'c2b9d063b86153fd9436fb07d8b3801d9ea40629964c422a22aac5a9eb9af3a1'

# 从节点退出集群的同时,相应的进程也会退出

3.迁移另外两个主节点slots槽数据到另一个主节点上

可以同时开两个窗口,一个窗口执行命令操作,另一个创建查看集群节点数等

最后只保留192.168.0.164:6379这一个主节点

# 迁移192.168.0.39:6379主节点数据
redis-cli --cluster reshard 192.168.0.39:6379 -a 'c2b9d063b86153fd9436fb07d8b3801d9ea40629964c422a22aac5a9eb9af3a1'

# 会出现一下问答对话项
#需要移动数据槽的数量
How many slots do you want to move (from 1 to 16384)? 5162  ==》这个数字是要填写192.168.0.39:6379 这个主节点的槽位数,上面显示的有

#需要接受数据槽的主节点ID,这里我们填写192.168.0.164:6379这一个主节点ID
What is the receiving node ID? 5a308d09f6372ff8a361c0e074c9f57d783dc9c6
 
#填写数据槽来源节点
Please enter all the source node IDs.
  Type 'all' to use all the nodes as source nodes for the hash slots.
  Type 'done' once you entered all the source nodes IDs.
Source node #1: a745e59c190f629d04905550f341d67dea47758f   =》 这个填写主节点 192.168.0.39:6379的节点ID,也就是要移除的主节点
Source node #2: done =》输入这个开始执行迁移

# 删除这个主节点
redis-cli --cluster del-node 192.168.0.39:6379 a745e59c190f629d04905550f341d67dea47758f -a 'c2b9d063b86153fd9436fb07d8b3801d9ea40629964c422a22aac5a9eb9af3a1'


redis-cli --cluster reshard 192.168.0.164:6380 -a 'c2b9d063b86153fd9436fb07d8b3801d9ea40629964c422a22aac5a9eb9af3a1'

# 删除这个主节点
redis-cli --cluster del-node 192.168.0.164:6380 abb2ab96ce5f65d0bc4362aa775274c8090be2af -a 'c2b9d063b86153fd9436fb07d8b3801d9ea40629964c422a22aac5a9eb9af3a1'

4.登录到最后保留的主节点上,执行save命令

[root@database01 ~]# redis-cli -c -h 192.168.0.164 -p 6379
192.168.0.164:6379> auth c2b9d063b86153fd9436fb07d8b3801d9ea40629964c422a22aac5a9eb9af3a1
OK
192.168.0.164:6379> save
192.168.0.164:6379> CONFIG GET dir  => 获取dump.rdp文件保存路径

5.启动新节点的redis,找到dump.rdp文件保存路径后,停止redis,删除该目录下默认生成的dump.rdp文件,把上一步获取到的dump.rdp文件放在这个目录下,注意dump.rdp文件文件的权限,最后再启动redis

登录redis后执行命令:keys *,查看key的个数是不是跟原先集群中的keys个数一样

标签:node,三主三,redis,192.168,6379,0.164,操作步骤,节点
From: https://www.cnblogs.com/hahaha111122222/p/17141175.html

相关文章

  • redis探秘:选择合适的数据结构,减少80%的内存占用,这些点你get到了吗?
    ​redis作为目前最流行的nosql缓存数据库,凭借其优异的性能、丰富的数据结构已成为大部分场景下首选的缓存工具。由于redis是一个纯内存的数据库,在存放大量数据时,内存的占用......
  • redis-命令操作-String&hash,list,set&sortedset,通用命令
    redis-命令操作-String&hashString类型存储:setkeyvalue获取:getkey删除:delkey  Hash类型存储:hsetkeyfieldvalue获取:hgetkeyfiled:获取指定的field对应......
  • redis-数据结构介绍
    redis的数据结构介绍redis的数据结构redis存储的是:key,value格式的数据,其中key都是字符串,value有五种不同的数据结构value的数据结构:字符串类......
  • redis-概述、redis下载&安装
    redis概述redis是一款高性能的NOSQL系列的非关系型数据库 什么是NOSQLNoSQL(NoSQL=NotOnlySQL),意即"不仅仅是SQL",是一项全新的数据库理念,泛指非关系型的数据......
  • redis使用冒号会更快吗
    前言最近在学习Redis相关知识,看了阿里的redis开发规范,以及Redis开发与运维这本书。分使用规范、有坑的命令、项目实战操作、运维配置四个方向。整理了使用Redis的21个注意......
  • redission删除key
    RBucket<Object>bucket=REDISSON_CLIENT.getBucket("queryRed"+userId);if(bucket.isExists()){bucket.delete();resultMap.put("c......
  • docker多容器之间的连接(Flask和Redis)
    (一)docker多容器的应用使用flask编写一个web应用,将数据存放于redis中在docker开发中,我们应该遵循每个容器只做一件事的原则我们运行两个容器,一个用于运行fla......
  • vue2,nginx,redis,tomcat,Java的关系
    Java作为一种广泛应用的编程语言,在后端开发中扮演着重要的角色。Java后端开发不仅需要掌握Java语言的基本语法和相关技术,还需要熟悉一些其他的技术和工具,如Vue2、Nginx、Re......
  • MyBatis-RedisCache源码分析
    回顾在前面,我们通过redis​集成了MyBatis​的二级缓存,440.MyBatis的二级缓存整合redis,接下来,我们来分析一下RedisCache​的源码。源码分析RedisCache主要是通过......
  • redis-6.2
    1.事务(1).命令行形式首先是开启事务命令multi,执行完数据修改后EXEC提交事务,DISCARD取消事务  (2).代码形式pipe=r.pipeline()#创建一个管道pipe.multi()pi......