java操作redis的坑(持续输出)
redis在java日常操作中是必不可少的工具了,但其中也会有一些不容易避免的错误,所以一旦遇到,即在本帖记录,大家有遇到其他问题,欢迎评论讨论。
一、使用redis的Set数据结构,设置过期时间未生效
// 获取reidsKey的Set结构redis操作类
String redisKey = "key";
BoundSetOperations bso = redisTemplate.boundSetOps(redisKey);
// 在操作该key之前,设置这个key的过期时间
bso.expire(20, TimeUnit.SECONDS);
// 初始化值
List<String> valueList = Arrays.asList("value1", "value2", "value3");
// 初始化key,设置key的过期时间后,往key中添加元素
bso.add(valueList .toArray());
现象:程序执行完成后,查看redis
的过期时间,结果是-1
---永不过期
结论:在操作redis
时,在无key的情况下设置过期时间是无效的,必须得首先保证redis中存在key后,然后设置该key的过期时间才行。反之则无效
二、通过redisTemplate
的multiGet
方法进行key的批量查询,即使没有key,返回的List也不会为空。
测试代码:
// 从缓存中批量获取数据
List<String> queryKeys= Arrays.asList("key1", "key2", "key3");
List<Object> objectsInRedis = redisTemplate.opsForValue().multiGet(queryKeys);
log.debug("批量获取redis中的数据,keys:{}, data:{}", queryKeys, objectsInRedis);
打印结果
2021-08-05 16:35:48.079 INFO 13248 --- [nio-1024-exec-2] com.feiGieGie.demo.controller.DemoController : 批量获取redis中的数据,keys:[key1, key2, key3], data:[null, null, null]
现象:待查询的queryKeys
,实际在redis中不存在这些key,按理来说查出来的List中应该是空集合,亦或是List为null,但实际是List并不为null也不为空,而是无论待查询的keys是否存在,返回的List中的元素个数就是key的个数,每个元素都是null。
结论:通过redisTemplate
的multiGet
方法进行key的批量查询,结果返回的List都要对每个元素进行null值过滤。实际也不难理解,因为批量查询的key,确实可能会存在部分key存在,部分key不存在,所以会将每个key的查询结果放入List中,这样返回的List便不可能为null或空集合。