大多数情况下,我们都会通过请求-相应机制去操作redis.只用这种模式的一般的步骤是,先获得jedis实例,然后通过jedis的get/put方法与redis交互.由于redis是单线程的,下一次请求必须等待上一次请求执行完成后才能继续执行.然而使用Pipeline模式,客户端可以一次性的发送多个命令,无需等待服务端返回.这样就大大的减少了网络往返时间,提高了系统性能. 下面用一个例子测试这两种模式在效率上的差别: public class PiplineTest { private stati
有时候,我们需要给redis库中插入大量的数据,如做性能测试前的准备数据.遇到这种情况时,偶尔可能也会懵逼一下,这里就给大家介绍一个批量导入数据的方法. 先准备一个redis protocol的文件(redis protocol可以参考这里:https://redis.io/topics/protocol),这里是用java程序来输出的,java代码如下: <<RedisBatchTest>> public class RedisBatchTest { public static
首先准备数据文件 格式为 SET Key0 Value0 SET Key1 Value1 ... SET KeyN ValueN 利用shell转换数据 #!/bin/bash while read CMD; do # each command begins with *{number arguments in command}\r\n XS=($CMD); printf "*${#XS[@]}\r\n" # for each argument, we append ${length}
1.首先把redis命令放在txt文件中 eg: 文件名: test.txt 内容如下: HMSET HM_001 name zhang01 age HMSET HM_002 name zhang02 age HMSET HM_003 name zhang03 age HMSET HM_004 name zhang04 age 存放位置: /home/redis/tmp 2.执行命令: (1).进入redis的安装目录 (2).其中127.0.0.1为自己的IP,6379为端口 cat /ho
一.遇到的问题 在开发的过程中,经常会遇到要批量删除某种规则的key,如缓存的课程数据“course-课程uid”,其中课程uid是变量,我们需要删除"course-*"这一类的数据,但是这里就坑了,redis有提供批量查询一类key的命令keys,但是没有提供批量删除某种类型key的命令. 二.解决方案 先看看我们怎么解决. 1.先进入redis的客户端 cd redis所在目录/src ./redis-cli 2.初始化数据,模拟数据 > set course- OK >