几种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

mysql 导入 rdb_几种redis数据导出导入方式相关推荐

  1. 【redis】三种redis数据导出导入方式

    文章目录 1.概述 一.redis-dump方式 二.aof方式导入 三.rdb文件迁移方式 1.概述 转载:三种redis数据导出导入方式 一.redis-dump方式 redis-dump安装 y ...

  2. reids数据导出导入

    redis数据导出导入 1.结构 库 ip dir地址 源库 192.168.0.15 /usr/local/redis/ 目标库 192.168.0.174 /usr/local/redis/ 1. ...

  3. redis数据批量导入导出

    针对工作中可能用到 将某台服务器中的redis数据 导出然后导入到新的服务器中,一种方法是redis-dump工具,但是 他需要安装ruby环境,安装环境的过程中还可能出现意想不到的错误.所以不得不选 ...

  4. 涂抹mysql笔记-数据导出导入

    数据导出导入 <>利用CSV存储引擎加载数据:CSV存储引擎基于CSV格式文件存储数据,CSV格式是纯文本格式的文件,以逗号分隔取值.CSV引擎表的所有列值不能为空.Excel可以直接打开 ...

  5. 【MySQL基础篇】数据导出导入权限与local_infile参数

    [MySQL基础篇]数据导出导入权限与local_infile参数 问题背景 数据导出测试 创建测试库(在主库进行) 测试数据导出(在从库进行) 测试数据导入(在主库进行) 问题背景 MySQL高可用 ...

  6. 在pl/sql中使用exp/imp工具实现oracle数据导出/导入

    在pl/sql中使用exp/imp工具实现oracle数据导出/导入 2006年11月19日 星期日 10:59 Oracle 数据导入导出imp/exp就相当于oracle数据还原与备份.exp命令 ...

  7. 不同版本的SQL Server之间数据导出导入的方法及性能比较

    原文:不同版本的SQL Server之间数据导出导入的方法及性能比较 工作中有段时间常常涉及到不同版本的数据库间导出导入数据的问题,索性整理一下,并简单比较下性能,有所遗漏的方法也欢迎讨论.补充. 0 ...

  8. MySQL数据库基础(三)数据的导入导出、管理表记录、匹配条件

    数据的导入导出 搜索路径 查看搜索路径 安装时已经自动创建 命令:mysql > show variables like "secure_file_priv"; mysql& ...

  9. 【Mysql】Mysql数据库数据导出\导入

    如何在 MySQL / MariaDB 中导入导出数据,导入导出数据库文件.Excel.CSV - 卡拉云 本文介绍Mysql数据库数据导出及导入方法.以及重要补充内容 目录 1. MySQL 数据库 ...

最新文章

  1. os.makedirs和os.mkdir 生成文件夹
  2. 唠唠SE的集合-10——Collections工具类
  3. tensorflow 入门
  4. ie8下jquery改变PNG的opacity出现黑边,ie6下png透明解决办法
  5. 实验9:Problem D: 从点到面
  6. 【数据结构与算法】之深入解析“石子游戏IX”的求解思路与算法示例
  7. html div bgcolor,HTML body bgcolor transparent
  8. PHP基本语法(实例)
  9. python `__format__`
  10. complex类模板c++_高中地理综合题答题模板,学霸们都收藏了!
  11. 金蝶kis商贸采购单商品代码_金蝶KIS商贸高级版操作常见问题解答
  12. 【笔记】运筹(中)——Rita_Aloha
  13. SQLite数据库可视化工具【SQLiteStudio】的下载及安装
  14. 图片模糊怎么变清晰?用嗨格式图片无损放大器
  15. 麦马计算机科学和麦马数学专业,积极配合 成功申请麦克马斯特大学数学专业...
  16. 语言认知模型--的学习笔记
  17. MySQL表的四种分区类型
  18. Three.js光源梳理3——平行光(DirectionalLight)
  19. 虚拟桌面:VmwareVDI架构详解
  20. 线性代数方程组数值解法

热门文章

  1. [经验教程]iPhone苹果手机NFC功能在哪里能找到怎么开启苹果iPhone手机NFC功能?
  2. 计算机(大类)类本科,2021年中国本科院校专业大类细分专业名称详解
  3. Android架构组件-Architecture Components
  4. 机械工程还是计算机科学好,计算机科学技术、通信工程、机械制造及其自动化、电器工程及其自动化这几个专业哪个好...
  5. 提示“准备更新时出错”,苹果M1芯片版Mac怎样重装系统?
  6. python combinations_python – itertools.combinations()的输出
  7. dnf服务器维护几点结束,10月7日上午6点-10点服务器例行维护公告
  8. java中String数组的使用
  9. Html飞机大战(九): 使徒来袭 (设计敌机)
  10. 13、C语言中的单引号和双引号