SpringCache缓存自定义配置的示例分析
导读:本文共5006字符,通常情况下阅读需要17分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: Cacheable指定自定义属性详情请参考spring官网添加链接描述1.key的名字和TTL时间/***查询所有1级分类*@Cacheable代表当前方法的结果需要缓存,若缓存中有则方法不会调用,若缓存中没有会调用方法并将结果放入缓存*缓存默认行为:*a.若缓存中有则方法不会被调用*b.key默认自动生成,缓存的名字::SimpleKey[](自动生... ...
目录
(为您整理了一些要点),点击可以直达。Cacheable指定自定义属性
详情请参考spring官网添加链接描述
1.key的名字和TTL时间
/***查询所有1级分类*@Cacheable代表当前方法的结果需要缓存,若缓存中有则方法不会调用,若缓存中没有会调用方法并将结果放入缓存*缓存默认行为:*a.若缓存中有则方法不会被调用*b.key默认自动生成,缓存的名字::SimpleKey[](自动生成的key值)*c.缓存的value值,默认使用jdk序列化机制,将序列化后的数据存到redis*d.默认ttl时间为-1*@return*/@Cacheable(value={"category"},key="'TopCategorys'")@OverridepublicList<CategoryEntity>getTopCategorys(){System.out.println(".....getTopCategorys..........");longstartTime=System.currentTimeMillis();List<CategoryEntity>categoryEntityList=this.baseMapper.selectList(newQueryWrapper<CategoryEntity>().eq("parent_cid",0));System.out.println("消耗时间:"+(System.currentTimeMillis()-startTime));returncategoryEntityList;}
/***查询所有1级分类*@Cacheable代表当前方法的结果需要缓存,若缓存中有则方法不会调用,若缓存中没有会调用方法并将结果放入缓存*缓存默认行为:*a.若缓存中有则方法不会被调用*b.key默认自动生成,缓存的名字::SimpleKey[](自动生成的key值)*c.缓存的value值,默认使用jdk序列化机制,将序列化后的数据存到redis*d.默认ttl时间为-1*@return*///@Cacheable(value={"category"},key="'TopCategorys'")@Cacheable(value={"category"},key="#root.method.name")@OverridepublicList<CategoryEntity>getTopCategorys(){System.out.println(".....getTopCategorys..........");longstartTime=System.currentTimeMillis();List<CategoryEntity>categoryEntityList=this.baseMapper.selectList(newQueryWrapper<CategoryEntity>().eq("parent_cid",0));System.out.println("消耗时间:"+(System.currentTimeMillis()-startTime));returncategoryEntityList;}
2.缓存数据保存为json格式
* 原理:
* CacheAutoConfiguration(selectImports方法)--->CacheConfigurations(MAPPINGS)
* --->RedisCacheConfiguration-->cacheManager方法--->RedisCacheManager初始化所有的缓存(determineConfiguration方法
* 每个缓存决定使用什么配置) --->createConfiguration方法
在config包下新建MyCacheConfig配置类
packagecom.atguigu.gulimall.product.config;importorg.springframework.boot.autoconfigure.cache.CacheProperties;importorg.springframework.cache.annotation.EnableCaching;importorg.springframework.context.annotation.Bean;importorg.springframework.context.annotation.Configuration;importorg.springframework.data.redis.cache.RedisCacheConfiguration;importorg.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;importorg.springframework.data.redis.serializer.RedisSerializationContext;importorg.springframework.data.redis.serializer.StringRedisSerializer;/***缓存配置*@authorzfh*@emailhst1406959716@163.com*@date2021-12-2509:40:46*/@EnableCaching@ConfigurationpublicclassMyCacheConfig{@BeanRedisCacheConfigurationredisCacheConfiguration(){RedisCacheConfigurationconfig=RedisCacheConfiguration.defaultCacheConfig();//config=config.entryTtl();config=config.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(newStringRedisSerializer()));config=config.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(newGenericJackson2JsonRedisSerializer()));returnconfig;}}
发现ttl变成了-1,我们的application.properties没起作用
packagecom.atguigu.gulimall.product.config;importorg.springframework.boot.autoconfigure.cache.CacheProperties;importorg.springframework.boot.context.properties.EnableConfigurationProperties;importorg.springframework.cache.annotation.EnableCaching;importorg.springframework.context.annotation.Bean;importorg.springframework.context.annotation.Configuration;importorg.springframework.data.redis.cache.RedisCacheConfiguration;importorg.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;importorg.springframework.data.redis.serializer.RedisSerializationContext;importorg.springframework.data.redis.serializer.StringRedisSerializer;/***缓存配置*@authorzfh*@emailhst1406959716@163.com*@date2021-12-2509:40:46*/@EnableConfigurationProperties(CacheProperties.class)@EnableCaching@ConfigurationpublicclassMyCacheConfig{@BeanRedisCacheConfigurationredisCacheConfiguration(CachePropertiescacheProperties){RedisCacheConfigurationconfig=RedisCacheConfiguration.defaultCacheConfig();//config=config.entryTtl();config=config.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(newStringRedisSerializer()));config=config.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(newGenericJackson2JsonRedisSerializer()));CacheProperties.RedisredisProperties=cacheProperties.getRedis();//将配置文件中所有的配置都生效if(redisProperties.getTimeToLive()!=null){config=config.entryTtl(redisProperties.getTimeToLive());}if(redisProperties.getKeyPrefix()!=null){config=config.prefixKeysWith(redisProperties.getKeyPrefix());}if(!redisProperties.isCacheNullValues()){config=config.disableCachingNullValues();}if(!redisProperties.isUseKeyPrefix()){config=config.disableKeyPrefix();}returnconfig;}}
3.使用缓存前缀
在application.properties文件中
spring.cache.type=redis#spring.cache.cache-names=qq#TTL毫秒为单位spring.cache.redis.time-to-live=3600000#如果指定了前缀就用我们指定的前缀,如果没有就默认使用缓存的名字作为前缀spring.cache.redis.key-prefix=CACHE_spring.cache.redis.use-key-prefix=true
4.缓存null,防止缓存穿透
在application.properties文件中
spring.cache.type=redis#spring.cache.cache-names=qq#TTL毫秒为单位spring.cache.redis.time-to-live=3600000#如果指定了前缀就用我们指定的前缀,如果没有就默认使用缓存的名字作为前缀spring.cache.redis.key-prefix=CACHE_spring.cache.redis.use-key-prefix=true#是否缓存空值,防止缓存穿透spring.cache.redis.cache-null-values=true
代码中直接返回null
/***查询所有1级分类*@Cacheable代表当前方法的结果需要缓存,若缓存中有则方法不会调用,若缓存中没有会调用方法并将结果放入缓存*缓存默认行为:*a.若缓存中有则方法不会被调用*b.key默认自动生成,缓存的名字::SimpleKey[](自动生成的key值)*c.缓存的value值,默认使用jdk序列化机制,将序列化后的数据存到redis*d.默认ttl时间为-1**原理:*CacheAutoConfiguration(selectImports方法)--->CacheConfigurations(MAPPINGS)*--->RedisCacheConfiguration-->cacheManager方法--->RedisCacheManager初始化所有的缓存(determineConfiguration方法*每个缓存决定使用什么配置)--->createConfiguration方法*@return*///@Cacheable(value={"category"},key="'TopCategorys'")@Cacheable(value={"category"},key="#root.method.name")@OverridepublicList<CategoryEntity>getTopCategorys(){System.out.println(".....getTopCategorys..........");longstartTime=System.currentTimeMillis();List<CategoryEntity>categoryEntityList=this.baseMapper.selectList(newQueryWrapper<CategoryEntity>().eq("parent_cid",0));System.out.println("消耗时间:"+(System.currentTimeMillis()-startTime));//returncategoryEntityList;returnnull;}
</div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
SpringCache缓存自定义配置的示例分析的详细内容,希望对您有所帮助,信息来源于网络。