Redis批量导入数据的方法

栏目: 数据库 · 发布时间: 5年前

内容简介:有时候,我们需要给redis库中插入大量的数据,如做性能测试前的准备数据。遇到这种情况时,偶尔可能也会懵逼一下,这里就给大家介绍一个批量导入数据的方法。先准备一个redis protocol的文件(redis protocol可以参考这里:https://redis.io/topics/protocol),这里是用java程序来输出的,java代码如下:<<RedisBatchTest>>

有时候,我们需要给 redis 库中插入大量的数据,如做性能测试前的准备数据。遇到这种情况时,偶尔可能也会懵逼一下,这里就给大家介绍一个批量导入数据的方法。

先准备一个redis protocol的文件(redis protocol可以参考这里:https://redis.io/topics/protocol),这里是用 java 程序来输出的,java代码如下:

<>

public class RedisBatchTest {

public static void main(String[] args) {

String outputFile = "d:\\temp\\redis_input.txt";

RedisBatchTest test = new RedisBatchTest();

test.generateFile(outputFile);

}

/**

* 格式化成输入字符串

*

* @param args

* @return

*/

private String getString(String key, String value) {

StringBuilder sb = new StringBuilder();

sb.append("*3").append("\r\n");

sb.append("$3").append("\r\n");

sb.append("SET\r\n");

sb.append("$").append(key.getBytes().length).append("\r\n");

sb.append(key).append("\r\n");

sb.append("$").append(value.getBytes().length).append("\r\n");

sb.append(value).append("\r\n");

return sb.toString();

}

public void generateFile(String file) {

BufferedWriter w = null;

String key = null;

String value = null;

StringBuilder sb = new StringBuilder();

try {

w = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(file), "utf-8"));

for (int i = 1; i <= 380; i++) {

key = "test_batch_" + i;

value = "v_" + i + "注册即送水电费ServiceTest"; // 这是key对应的value

sb.append(this.getString(key, value));

if (i % 10 == 0) {

w.write(sb.toString());

w.flush();

sb.delete(0, sb.length());

System.out.println("Current write: " + i);

}

}

} catch (Exception e) {

e.printStackTrace();

} finally {

try {

w.flush();

w.close();

} catch (IOException e) {

e.printStackTrace();

}

}

}

}

执行以上代码,就会在d:\\temp目录下生成一个文本文件,格式如下:

Redis批量导入数据的方法

以上就是redis protocol格式的文件了,请上传到要执行的机器上。然后使用以下命令来执行它:

cat input/redis_input.txt | bin/redis-cli -p 6370 -a yourpasswd –pipe

如果执行成功的话,你就可以看到如下信息了:

Redis批量导入数据的方法

从以上输出可以看出,380条数全部插入到redis服务器上啦。

更详细的信息,可以参考: https://redis.io/topics/mass-insert


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Java核心技术·卷1:基础知识(原书第9版)

Java核心技术·卷1:基础知识(原书第9版)

(美)Cay S. Horstmann、(美)Gary Cornell / 周立新、陈波、叶乃文、邝劲筠、杜永萍 / 机械工业出版社 / 2013-11-1 / 119.00

Java领域最有影响力和价值的著作之一,拥有20多年教学与研究经验的资深Java技术专家撰写(获Jolt大奖),与《Java编程思想》齐名,10余年全球畅销不衰,广受好评。第9版根据JavaSE7全面更新,同时修正了第8版中的不足,系统全面讲解Java语言的核心概念、语法、重要特性和开发方法,包含大量案例,实践性强。 《Java核心技术·卷1:基础知识》共14章。第1章概述了Java语言与其......一起来看看 《Java核心技术·卷1:基础知识(原书第9版)》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具