spring cache设置默认自定义的的keyGenerator。

创建了自定义的keyGenerator之后。每次要使用的话经常需要CacheConfig。为了省去这个步骤,直接设置自定义的keyGenerator为默认。设置之后呢,就不需要设置CacheConfig。只需要在方法上加上@Cacheable就可以了。

改动呢就是2点,一个是要继承这个类。还有呢,就是加上@Override就可以了。


/**
 * Created by 张某松 on 2020/6/10.
 */
@Configuration
@EnableCaching
public class CacheConfig extends CachingConfigurerSupport{
    org.slf4j.Logger logger= org.slf4j.LoggerFactory.getLogger(getClass());
    @Resource
    private RedisConnectionFactory redisConnectionFactory;//显示红色报错不用管。

    @Bean
    @Primary
    @Override   //继承上面这个类,并且加上这个之后才能把它设置为默认的。
    public KeyGenerator keyGenerator() {
        return new KeyGenerator() {
            @Override
            public Object generate(Object target, Method method, Object... params) {
                String re= String.format("%s::%s(%s)",target.getClass().getName(),method.getName(),
                        CollectionUtils.arrayToList(params));//Arrays.asList(params)
                logger.debug("缓存生成的key:{}。",re);
                return re;
            }
        };
    }

    @Bean
    @Primary
    @Override
    public CacheManager cacheManager() {
        super.cacheManager();
        RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofHours(1)); // 设置缓存有效期一小时
//                .serializeValuesWith(serializationPair());
        //genericJackson2JsonRedisSerializer()取代RedisSerializer.json()解决Could not read JSON: Cannot construct instance of `java.time.LocalTime` (no Creators, like default construct, exist)

//        RedisCacheManager redisCacheManager = RedisCacheManager
//                .builder(RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory))
//                .cacheDefaults(redisCacheConfiguration).build();
        Map<String, RedisCacheConfiguration> initialCacheConfigurations=new HashMap<>();
        initialCacheConfigurations.put("sixHoursCache",RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofHours(6)));
//                     这一行代码会导致空置针,但是上面设置这一项,却没有控制真错误
//                .serializeValuesWith(serializationPair()));;
//        initialCacheConfigurations.put("fiveMinutesCache",RedisCacheConfiguration.defaultCacheConfig()
//                .entryTtl(Duration.ofMinutes(5)));
//                .serializeValuesWith(serializationPair()));;
        initialCacheConfigurations.put("minuteCache",RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofMinutes(1)));
//                .serializeValuesWith(serializationPair()));
        RedisCacheManager redisCacheManager=new RedisCacheManager(RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory),
                redisCacheConfiguration,
                initialCacheConfigurations,
                true);
        return redisCacheManager;
    }
}

### 使用 `@Cacheable` 注解时自定义 `KeyGenerator` 为了实现更灵活的键生成策略,在使用 `@Cacheable` 注解时可以指定一个自定义的 `KeyGenerator` 来替代默认的行为。这允许开发者根据业务逻辑创建更加复杂和精确的缓存键。 #### 创建自定义 `KeyGenerator` 首先,需要定义一个新的类并让它实现了 `org.springframework.cache.interceptor.KeyGenerator` 接口: ```java import org.springframework.cache.interpreter.DefaultParameterNameDiscoverer; import org.springframework.cache.interceptor.KeyGenerator; public class CustomKeyGenerator implements KeyGenerator { private final DefaultParameterNameDiscoverer discoverer = new DefaultParameterNameDiscoverer(); @Override public Object generate(Object target, java.lang.reflect.Method method, Object... params) { StringBuilder sb = new StringBuilder(); String[] paramNames = discoverer.getParameterNames(method); if (paramNames != null && paramNames.length > 0) { for (int i = 0; i < paramNames.length; ++i) { sb.append(paramNames[i]).append("=").append(params[i]); if (i < paramNames.length - 1) { sb.append("_"); } } } return sb.toString(); } } ``` 此代码片段展示了如何构建一个简单的字符串形式的键名,其中包含了方法参数名称与其对应的值[^1]。 #### 配置 Bean 接着要在 Spring 上下文中注册该 `CustomKeyGenerator` 实例作为 bean: ```xml <bean id="customKeyGenerator" class="com.example.CustomKeyGenerator"/> ``` 对于 Java Config 用户,则可以在配置类中添加如下内容: ```java @Configuration public class AppConfig { @Bean public KeyGenerator customKeyGenerator() { return new CustomKeyGenerator(); } } ``` #### 应用于 `@Cacheable` 最后一步是在目标服务层的方法上应用 `@Cacheable` 并指明要使用的 `keyGenerator` 属性: ```java @Service public class MyService { @Autowired private UserRepository userRepository; @Cacheable(value = "users", keyGenerator = "customKeyGenerator") public User findUser(String name, Integer age) { // ... some logic here ... return userRepository.findByNameAndAge(name, age); } } ``` 上述例子表明了当调用 `findUser` 方法时将会利用之前定义好的 `CustomKeyGenerator` 来计算唯一的缓存键[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值