使用spring boot2.x cache —— redis作为数据缓存方案时,可以采用@CacheEvict用来清除相应的数据缓存,但是@CacheEvict底层使用的redis的keys命令来遍历查找,但是keys太过暴力,不支持offset、limit参数,而且是遍历算法,复杂度为O(n),当redis中的数据量较大时,很容易造成服务卡顿阻塞,所以在正式环境keys这个命令是禁用的,那么@CacheEvict也就不可用了。
但是redis在2.8版本之后增加了scan命令,支持游标遍历查询,下文是用java实现的scan遍历及删除
Spring boot 集成redis参考另一篇:https://blog.csdn.net/qq_29721419/article/details/102709474
package com.kexin.utils;
import lombok.extern.slf4j.Slf4j;
import org.springframework.data.redis.core.Cursor;
import org.springframework.data.redis.core.RedisCallback;
import org.springframework.data.redis.core