业务场景:
有一个定时任务在查询需执行数据列表信息时,需要记录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);