前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SpringCache基本配置类

SpringCache基本配置类

作者头像
benym
发布2024-05-18 09:32:31
540
发布2024-05-18 09:32:31
举报
文章被收录于专栏:后端知识体系后端知识体系

# 起步依赖

代码语言:javascript
复制
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-cache</artifactId>
</dependency>

# SpringCacheConfig

同时配置带过期时间的CacheManager

自定义Json序列化方式存储

代码语言:javascript
复制
import cn.hutool.core.util.RandomUtil;
import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.JsonTypeInfo;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.SerializationFeature;
import com.fasterxml.jackson.databind.jsontype.impl.LaissezFaireSubTypeValidator;
import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule;
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.connection.RedisConnectionFactory;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializationContext;
import org.springframework.data.redis.serializer.StringRedisSerializer;

import java.time.Duration;

/**
 * spring cache配置
 */
@Configuration
public class SpringCacheConfig {

    /**
     * 随机数上界-1天时间内随机数
     */
    private static final long CACHE_RANDOM_LIMIT = 24 * 60 * 60 * 1000L;

    /**
     * 获取缓存时间
     * 缓存时间=sourceCacheTtl+random limit
     *
     * @param sourceCacheTtl sourceCacheTtl
     * @param limit          limit
     * @return long
     */
    private long cacheTtlWithRandom(long sourceCacheTtl, long limit) {
        long random = RandomUtil.randomLong(limit);
        return sourceCacheTtl + random;
    }

    /**
     * 同时随机过期时间解决缓存雪崩问题
     *
     * @return CacheManager
     */
    @Bean("testCache")
    public RedisCacheManager cacheManager1Day(RedisConnectionFactory connectionFactory) {
        // 3天过期时间,转换成毫秒
        long threeDaysInMillis = 3 * 24 * 60 * 60 * 1000L;
        // 过期时间和最大空闲时间都设为3天+随机时间
        long trueTtl = cacheTtlWithRandom(threeDaysInMillis, CACHE_RANDOM_LIMIT);
        RedisCacheConfiguration config = instanceConfig(trueTtl);
        return RedisCacheManager.builder(connectionFactory)
                .cacheDefaults(config)
                .transactionAware()
                .build();
    }

    /**
     * 初始化config
     *
     * @param ttl 超时时间
     * @return RedisCacheConfiguration
     */
    private RedisCacheConfiguration instanceConfig(Long ttl) {
        // value存储为JSON格式
        // 使用Jackson2JsonRedisSerialize 替换默认序列化
        Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<>(Object.class);
        // 指定objectMapper带输入类型的序列化,如果不指定redis中则存储纯json,序列化返回后解析默认为LinkedHashMap
        // 需要自己转换类型,指定序列化类型后无需再进行转化
        ObjectMapper objectMapper = new ObjectMapper();
        objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        objectMapper.enableDefaultTyping(LaissezFaireSubTypeValidator.instance,
                ObjectMapper.DefaultTyping.NON_FINAL, JsonTypeInfo.As.WRAPPER_ARRAY);
        // 处理LocalDateTime
        objectMapper.disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);
        objectMapper.registerModule(new JavaTimeModule());
        jackson2JsonRedisSerializer.setObjectMapper(objectMapper);
        return RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofSeconds(ttl))
                .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer()))
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer));

    }
}

带过期时间的CacheManager使用方法如下

代码语言:javascript
复制
@Cacheable(cacheNames = "TestName",
            key = "'123456'",
            cacheManager = "testCache",
            sync = true)

其中存储到Redis中的key的规则为

  • 当没有配置key时:key=cacheNames+::+SimpleKey [],如TestName::SimpleKey []
  • 当配置了key时:key=cacheNames+::+key,如TestName::123456
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-05-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • # 起步依赖
  • # SpringCacheConfig
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档