业务场景:

有一个定时任务在查询需执行数据列表信息时,需要记录clover某台机器查询数据的页码数
首先想到的是使用redis记录
设置了一个业务key前缀+机器编号作为key值,然后机器在取数的时候每次进来都获取已经执行过的页面数信息,处理完成后,更新页码,一直到获取数据为null则value值不再更新。因为改定时任务每日一次,每次也就十多分钟,因此当时设置的是10分钟过期,每次set都覆盖expires。

想象总是完美的,现实总是残酷的。

第二天执行的时候我发现并不是又重新从页码1开始的,而是紧接着前一天执行的页码开始执行的。也就是说更新key的value值导致设置的过期时间失效(一共有四个调度服务器实例)
在这里插入图片描述

问题原因

key值经设置了过期时间,再去重新设置它,就会导致之前的过期时间无效

解决方案

利用ttl去获取key值当前的失效时间,并在更新value值的时候赋进去。

int ttl = redisService.getTll(RedisConstant.SYNC_SKU_INFO_LOCK+i).intValue();
log.info("获取缓存失效时间:key:{}, ttl:{}, ", RedisConstant.SYNC_SKU_INFO_LOCK+i, ttl);
redisService.put(RedisConstant.SYNC_SKU_INFO_LOCK+i, ttl, page);

需要注意的是put值的时候,失效时间是秒还是毫秒级,默认expire是秒,pExpire设置时间是毫秒级,具体可以用TimeUnit设置。

expire(key, expires, TimeUnit.SECONDS);

参考文章

Redis 更新key值导致过期时间失效问题

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐