几种redis数据导出导入方式
admin
2023-02-06 22:40:04
0

几种redis数据导出导入方式

1 环境说明:

192.168.1.101 node1 redis源实例
192.168.1.102 node2 redis目标实例
192.168.1.103 node3 任意linux系统

2 redis-dump方式

2.1 安装RVM

redis-dump这款工具需要用到Ruby,而centos环境中的yum工具可以安装的Ruby版本最高是2.0的版本,而当前Redis最新的4.0版本中需要用到的Ruby >= 2.2版本,所以我们需要先安装Ruby,而安装Ruby有一个很好的命令行工具可以帮助我们,这款工具就是RVM,RVM可以提供一个便捷的多版本 Ruby 环境的管理和切换。

首先到tmp下,用来存放下载的安装文件
cd /tmp
mkdir rvm
cd rvm
# 开始安装RVM
gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 
curl -O https://raw.githubusercontent.com/rvm/rvm/master/binscripts/rvm-installer 
curl -O https://raw.githubusercontent.com/rvm/rvm/master/binscripts/rvm-installer.asc 
gpg --verify rvm-installer.asc 
bash rvm-installer stable 
source /etc/profile.d/rvm.sh

2.2 安装Ruby

查看可以安装的Ruby版本

rvm list known

这里我们安装2.4.1

rvm install ruby 2.4.1 

设置默认ruby

rvm use 2.4.1 --default

查看ruby版本

ruby --version

2.3 安装redis-dump工具

移除gem自带源(美国服务器下载慢)

gem sources --remove https://rubygems.org/ 

添加国内源

gem sources -a https://gems.ruby-china.com

查看仓库源

gem sources -l
*** CURRENT SOURCES ***

http://gems.ruby-china.com/

安装redis-dump

gem install redis-dump -V

安装redis-dump包括的gem包

drydock-0.6.9.gem
uri-redis-0.4.2.gem
yajl-ruby-1.4.1.gem
redis-dump-0.4.0.gem

2.4 redis-dump导出

redis-dump帮助命令

[root@node3 ~]# redis-dump --help
  Try: /usr/local/bin/redis-dump show-commands
Usage: /usr/local/bin/redis-dump [global options] COMMAND [command options]
    -u, --uri=S                      Redis URI (e.g. redis://hostname[:port])
    -d, --database=S                 Redis database (e.g. -d 15)
    -a, --password=S                 Redis password (e.g. -a 'my@pass/word')
    -s, --sleep=S                    Sleep for S seconds after dumping (for debugging)
    -c, --count=S                    Chunk size (default: 10000)
    -f, --filter=S                   Filter selected keys (passed directly to redis' KEYS command)
    -b, --base64                     Encode key values as base64 (useful for binary values)
    -O, --without_optimizations      Disable run time optimizations
    -V, --version                    Display version
    -D, --debug
        --nosafe
[root@node3 ~]#

导出命令

redis-dump -u 192.168.1.101:6379 > 192.168.1.101.json

导出指定数据库数据

redis-dump -u 192.168.1.101:6379 -d 5 > 192.168.1.101.json

如果redis设有密码

redis-dump -u :password@192.168.1.101:6379 > 192.168.1.101.json

redis-dump导出当前节点的所有keys;当redis 为cluster时,需要分别导出所有master的keys;

2.5 redis-load导入命令

[root@node3 ~]# redis-load --help
  Try: /usr/local/bin/redis-load show-commands
Usage: /usr/local/bin/redis-load [global options] COMMAND [command options]
    -u, --uri=S                      Redis URI (e.g. redis://hostname[:port])
    -d, --database=S                 Redis database (e.g. -d 15)
    -a, --password=S                 Redis password (e.g. -a 'my@pass/word')
    -s, --sleep=S                    Sleep for S seconds after dumping (for debugging)
    -b, --base64                     Decode key values from base64 (used with redis-dump -b)
    -n, --no_check_utf8
    -V, --version                    Display version
    -D, --debug
        --nosafe
[root@node3 ~]#

redis-load导入

cat 192.168.1.101.json | redis-load -u 192.168.1.102:6379

# 或者
< 192.168.1.101.json redis-load -u 192.168.1.102:6379

3 aof导入方式

3.1 源实例生成aof数据

# 清空上文目标实例全部数据
[root@node1 ~]# redis-cli -h 192.168.1.102 -a password flushall
OK
# 源实例开启aof功能,将在dir目录下生成appendonly.aof文件
[root@node1 ~]# redis-cli -h 192.168.1.101 -a password config set appendonly yes
OK

3.2 目标实例导入aof数据

# 假设appendonly.aof就在当前路径下
[root@node1 ~]# redis-cli -h 192.168.1.102 -a password --pipe < appendonly.aof
All data transferred. Waiting for the last reply...
Last reply received from server.
errors: 0, replies: 5
# 源实例关闭aof功能
[root@node1 ~]# redis-cli -h 192.168.1.101 -a password config set appendonly no
OK

4 rdb文件迁移方式

暂略

5 源实例db0迁移至目标实例db1

[root@node1 ~]# cat redis_mv.sh
#!/bin/bash
redis-cli -h 192.168.1.101 -p 6379 -a password -n 0 keys "*" | while read key
do
    redis-cli -h 192.168.1.101 -p 6379 -a password -n 0 --raw dump $key | perl -pe 'chomp if eof' | redis-cli -h 192.168.1.102 -p 6379 -a password -n 1 -x restore $key 0
    echo "migrate key $key"
done

相关内容

热门资讯

终于懂了“秀山博胡开挂器?”(... 有 亲,根据资深记者爆料秀山博胡是可以开挂的,确实有挂(咨询软件无需打开...
【今日要闻】“至尊麻将到底有挂... 家人们!今天小编来为大家解答至尊麻将透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里买很...
【第一消息】“福麻圈怎么开挂?... 有 亲,根据资深记者爆料福麻圈是可以开挂的,确实有挂(咨询软件无需打开直...
今日重大消息“微信红包开挂器?... 您好:微信红包这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游戏...
【第一消息】“同乐吧到底是不是... 【第一消息】“同乐吧到底是不是挂?”(其实是有挂)您好,同乐吧这个游戏其实有挂的,确实是有挂的,需要...
终于懂了“凉山跑得快开挂器?”... 终于懂了“凉山跑得快开挂器?”(详细开挂教程)您好,凉山跑得快这个游戏其实有挂的,确实是有挂的,需要...
今日重磅消息“麦穗app推筒子... 您好:麦穗app推筒子这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在...
玩家分享攻略“闲逸斗地主辅助器... 您好:闲逸斗地主这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游...
玩家最新攻略“新超圣炸/金/花... 网上科普关于“新超圣炸/金/花有没有挂”话题很是火热,小编也是针对新超圣炸/金/花作*弊开挂的方法以...
今日重大消息“斗棋麻将有挂吗?... 有 亲,根据资深记者爆料斗棋麻将是可以开挂的,确实有挂(咨询软件无需打开...