SpringCache缓存自定义配置的示例分析(springcache,开发技术)

时间:2024-05-03 07:16:13 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

Cacheable指定自定义属性

SpringCache缓存自定义配置的示例分析

详情请参考spring官网添加链接描述

1.key的名字和TTL时间

SpringCache缓存自定义配置的示例分析

/***查询所有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;}

SpringCache缓存自定义配置的示例分析

/***查询所有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;}

SpringCache缓存自定义配置的示例分析

2.缓存数据保存为json格式

SpringCache缓存自定义配置的示例分析

SpringCache缓存自定义配置的示例分析

SpringCache缓存自定义配置的示例分析

SpringCache缓存自定义配置的示例分析

SpringCache缓存自定义配置的示例分析

* 原理:
* 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;}}

SpringCache缓存自定义配置的示例分析

发现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;}}

SpringCache缓存自定义配置的示例分析

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

SpringCache缓存自定义配置的示例分析

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;}

SpringCache缓存自定义配置的示例分析

 </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
本文:SpringCache缓存自定义配置的示例分析的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:Vue如何实现顶部tags浏览历史下一篇:

11 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18