绝对没问题,springboot2集成redis3.2.100 完善配置并指定缓存时间包含原来的序列化

redisi配置以及序列化可参考我之前写的博客,这里主要完善下配置信息,可以自定义缓存时间。

配置代码:

import com.newcapec.common.cache.factory.ICache;
import org.springframework.cache.CacheManager;
import org.springframework.cache.annotation.CachingConfigurerSupport;
import org.springframework.cache.annotation.EnableCaching;
import org.springframework.cache.interceptor.KeyGenerator;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.cache.RedisCacheConfiguration;
import org.springframework.data.redis.cache.RedisCacheManager;
import org.springframework.data.redis.cache.RedisCacheWriter;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.JdkSerializationRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializationContext;
import org.springframework.data.redis.serializer.StringRedisSerializer;
import java.time.Duration;
import java.util.HashMap;
import java.util.Map;

@Configuration
@EnableCaching
public class RedisConfiguration extends CachingConfigurerSupport {

    @Bean
    public KeyGenerator simpleKeyGenerator() {
        return (o, method, objects) -> {
            StringBuilder stringBuilder = new StringBuilder();
            stringBuilder.append(o.getClass().getSimpleName());
            stringBuilder.append(".");
            stringBuilder.append(method.getName());
            stringBuilder.append("[");
            for (Object obj : objects) {
                stringBuilder.append(obj.toString());
            }
            stringBuilder.append("]");

            return stringBuilder.toString();
        };
    }
    /*
     * @Author 冒菜
     * @Description //防止redis入库序列化乱码的问题
     * @Date 16:21 2019/6/6
     * @Param
     * @return
     **/
    @Bean
    public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory){
        RedisTemplate<Object, Object> redisTemplate = new RedisTemplate<Object, Object>();
        redisTemplate.setConnectionFactory(redisConnectionFactory);
        redisTemplate.setKeySerializer(new StringRedisSerializer());//key序列化
        redisTemplate.setHashKeySerializer(new StringRedisSerializer());
        redisTemplate.afterPropertiesSet();
        return redisTemplate;
    }

    @Bean
    public CacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
        return new RedisCacheManager(
                RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory),
                // 默认策略,@Cacheable未配置的 key 会使用这个,默认过期时间
                this.getRedisCacheConfigurationWithTtl(ICache.CONSTANTTIME),//默认策略  100分钟
                this.getRedisCacheConfigurationMap() // 指定 key 策略
        );
    }


    private RedisCacheConfiguration getRedisCacheConfigurationWithTtl(Long seconds) {
        // 设置CacheManager的值序列化方式为JdkSerializationRedisSerializer,
        // 但其实RedisCacheConfiguration默认就是使用StringRedisSerializer序列化key,JdkSerializationRedisSerializer序列化value
        ClassLoader loader = this.getClass().getClassLoader();
        JdkSerializationRedisSerializer jdkSerializer = new JdkSerializationRedisSerializer(loader);
        RedisSerializationContext.SerializationPair<Object> pair = RedisSerializationContext.SerializationPair.fromSerializer(jdkSerializer);
        RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig();
        redisCacheConfiguration = redisCacheConfiguration.serializeValuesWith(pair).entryTtl(Duration.ofSeconds(seconds));
        return redisCacheConfiguration;
    }

    private Map<String, RedisCacheConfiguration> getRedisCacheConfigurationMap() {
        Map<String, RedisCacheConfiguration> redisCacheConfigurationMap = new HashMap<>();
        //自定义缓存策略可指定缓存时间,目前使用全局Key指定,缓存时间为5分钟
        redisCacheConfigurationMap.put(ICache.CONSTANT2, this.getRedisCacheConfigurationWithTtl(ICache.CONSTANT2TIME));
        return redisCacheConfigurationMap;
    }

}

接口中的两个配置引入:

/**
 * redis默认缓存策略有效时间单位ms(100分钟)全局定义的指定缓存策略 by wwb
 */
public long CONSTANTTIME = 300L;
/**
 * redis制定缓存策略有效时间单位ms(100分钟)全局定义的指定缓存策略 by wwb
 */
public long CONSTANT2TIME = 6000L;

 

如果想自定义使用其他时间或多个自定义时间配置,只需要在

getRedisCacheConfigurationMap方法中Put就可以了。

使用方法参考:

cacheNames指定配置的缓存策略,不指定的话使用默认的

@Cacheable(cacheNames= ICache.CONSTANT2, key="#termcode", unless="#result == null")
public AifaceTerm getOnlineTerminfo(String termcode){
   AifaceTerm term = termDao.getTermByTermcode(termcode,1);
   return term;
}

另外常用的几个缓存注解建议了解下。

这里遗留一个问题:如何自定义设置缓存的大小和条数? 希望那位大佬或朋友解决了能评论我或私信我学习一下,非常感谢

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不能吃辣的JAVA程序猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值