广告
返回顶部
首页 > 资讯 > 数据库 >几种redis数据导出导入方式
  • 671
分享到

几种redis数据导出导入方式

2024-04-02 19:04:59 671人浏览 独家记忆
摘要

几种Redis数据导出导入方式 1 环境说明: 192.168.1.101 node1 redis源实例 192.168.1.102 node2 redis目标实例 192.168.1.103 node3

几种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
您可能感兴趣的文档:

--结束END--

本文标题: 几种redis数据导出导入方式

本文链接: https://www.lsjlt.com/news/41023.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 几种redis数据导出导入方式
    几种redis数据导出导入方式 1 环境说明: 192.168.1.101 node1 redis源实例 192.168.1.102 node2 redis目标实例 192.168.1.103 node3 ...
    99+
    2022-10-18
  • R语言导入导出数据的几种方法汇总
    导出: 对于某一数据集导出文件的方法 导出例子:write.csv(data_1,file = "d:/1111111111.csv") 其中data_1是你的数据集,file是你...
    99+
    2022-11-11
  • Mysql导入导出几种方式+查看修改数据库字符集方法
    三.从数据库导出数据库文件: 1.将数据库mydb导出到文件中: 打开开始->运行->输入cmd 进入命令行模式 c:\>MySQLdump -h localhost -u root -p...
    99+
    2022-10-18
  • redis数据如何导入导出
    redis数据导入导出的方法:通过redis-dump工具进行导入导出,在终端命令行通过以下命令进行安装。//安装redis-dump工具[root@202.102.221.13 ~]$ yum install ruby rubygems ...
    99+
    2022-10-10
  • Mysql数据库的导入导出方式(各种情况)
    目录情况一本地导出,远程导入(windows导到linux)情况二linux导到linux情况三linux系统中的数据库导出,导入到本地windows系统总结情况一 本地导出,远程导...
    99+
    2023-03-08
    Mysql数据库 Mysql数据库导入 Mysql数据库导出
  • python导入导出redis数据的实现
    目录一.导出redis某个库的数据使用python向Redis批量导入数据二.导入redis某个库的数据注:以String类型为例 一.导出redis某个库的数据 import re...
    99+
    2022-11-13
  • PyCharm导入numpy库的几种方式
    numpy导入 有两种方式可以导入: 第一种:输入代码块 在Terminal输入pip install numpy 第二种:视图 1.打开settings 2、打开Python ...
    99+
    2022-11-12
  • oracle导入导出数据的方式有哪些
    Oracle数据库有多种方式可以导入和导出数据。以下是常用的几种方式:1. 使用SQL Developer:Oracle提供了一个免...
    99+
    2023-08-23
    oracle
  • 数据导入导出
    数据导入导出设置数据导入/导出使用的目录1.查看默认使用目录及目录是否存在。mysql>show variables like "secure_file_priv";secure_...
    99+
    2022-10-18
  • mysql中数据库覆盖导入的几种方式总结
    目录部分覆盖业务场景应用方案完全覆盖业务场景应用方案总结众所周知,数据库中INSERT INTO语法是append方式的插入,而最近在处理一些客户数据导入场景时,经常遇到需要覆盖式导...
    99+
    2022-11-13
  • Mysql数据库的导入导出方式有哪些
    本文小编为大家详细介绍“Mysql数据库的导入导出方式有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“Mysql数据库的导入导出方式有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。情况一本地导出,远程导...
    99+
    2023-07-05
  • Redis数据导入导出以及数据迁移的方法有哪些
    这篇文章主要介绍了Redis数据导入导出以及数据迁移的方法有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、aof 导入方式。因为这种...
    99+
    2022-10-18
  • redis中使用redis-dump导出、导入、还原数据实例
    redis的备份和还原,借助了第三方的工具,redis-dump 1、安装redis-dump [root@localhost tank]# yum install ruby rubygems ruby-...
    99+
    2022-06-04
    实例 数据 redis
  • oracle 数据导入导出
    I am the new of Oracle , and that i need to learn more about it . But as you know , here is the company...
    99+
    2022-10-18
  • 数据泵导出导入
    出于许多原因,我们期望从某个数据库中提取大量数据以及关联的对象定义,并且采用一种更容易的方式将这些数据载入到另一个数据库中。备份就是其中一个重要原因,另外可能需要在生产与测试环境之间或联机系统与数据仓库之...
    99+
    2022-10-18
  • MySQL数据导入和导出纯数据的方式有哪些
    小编给大家分享一下MySQL数据导入和导出纯数据的方式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! ...
    99+
    2022-10-18
  • MySQL数据库导入导出数据的方法
    这篇文章主要介绍“MySQL数据库导入导出数据的方法”,在日常操作中,相信很多人在MySQL数据库导入导出数据的方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL数...
    99+
    2022-10-18
  • mysql数据库导入、导出
    终端命令操作(导出) 导出整个库 mysqldump -u 用户名 -p 数据库名 > 导出的文件名 mysqldump -u root-p blog > ./blog.sql   2导出某个表 mysqldump -u 用户名 ...
    99+
    2020-08-22
    mysql数据库导入 导出
  • MongoDB数据导入导出(8)
    导出数据 导入/导出可以操作的是本地的mongodb服务器,也可以是远程的,所以,都有如下通用选项。 利用mongoexport -h host 主机 -port 端口 -d 知名使用的库 -c 指明要导出的集合 -o 指明要导出...
    99+
    2014-12-22
    MongoDB数据导入导出(8)
  • Python中几种导入模块的方式总结
    模块内部封装了很多实用的功能,有时在模块外部调用就需要将其导入。常见的方式有如下几种: 1 . import >>> import sys >>> sys.path ...
    99+
    2022-06-04
    几种 模块 方式
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作