SpringCache缓存自定义配置的示例分析
SpringCache缓存自定义配置的示例分析
这篇文章将为大家详细讲解有关SpringCache缓存自定义配置的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
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;}
关于“SpringCache缓存自定义配置的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。