SpringCache緩存自定義配置的實(shí)現(xiàn)
Cacheable指定自定義屬性
詳情請參考spring官網(wǎng)添加鏈接描述
1.key的名字和TTL時(shí)間
/** * 查詢所有1級(jí)分類 * @Cacheable代表當(dāng)前方法的結(jié)果需要緩存,若緩存中有則方法不會(huì)調(diào)用,若緩存中沒有會(huì)調(diào)用方法并將結(jié)果放入緩存 * 緩存默認(rèn)行為: * a.若緩存中有則方法不會(huì)被調(diào)用 * b.key默認(rèn)自動(dòng)生成,緩存的名字::SimpleKey [] (自動(dòng)生成的key值) * c.緩存的value值,默認(rèn)使用jdk序列化機(jī)制,將序列化后的數(shù)據(jù)存到redis * d.默認(rèn)ttl時(shí)間為-1 * @return */ @Cacheable(value = {"category"},key ="'TopCategorys'" ) @Override public List<CategoryEntity> getTopCategorys() { System.out.println(".....getTopCategorys.........."); long startTime = System.currentTimeMillis(); List<CategoryEntity> categoryEntityList = this.baseMapper.selectList( new QueryWrapper<CategoryEntity>().eq("parent_cid", 0)); System.out.println("消耗時(shí)間:" + (System.currentTimeMillis() - startTime)); return categoryEntityList; }
/** * 查詢所有1級(jí)分類 * @Cacheable代表當(dāng)前方法的結(jié)果需要緩存,若緩存中有則方法不會(huì)調(diào)用,若緩存中沒有會(huì)調(diào)用方法并將結(jié)果放入緩存 * 緩存默認(rèn)行為: * a.若緩存中有則方法不會(huì)被調(diào)用 * b.key默認(rèn)自動(dòng)生成,緩存的名字::SimpleKey [] (自動(dòng)生成的key值) * c.緩存的value值,默認(rèn)使用jdk序列化機(jī)制,將序列化后的數(shù)據(jù)存到redis * d.默認(rèn)ttl時(shí)間為-1 * @return */ // @Cacheable(value = {"category"},key ="'TopCategorys'" ) @Cacheable(value = {"category"},key ="#root.method.name" ) @Override public List<CategoryEntity> getTopCategorys() { System.out.println(".....getTopCategorys.........."); long startTime = System.currentTimeMillis(); List<CategoryEntity> categoryEntityList = this.baseMapper.selectList( new QueryWrapper<CategoryEntity>().eq("parent_cid", 0)); System.out.println("消耗時(shí)間:" + (System.currentTimeMillis() - startTime)); return categoryEntityList; }
2.緩存數(shù)據(jù)保存為json格式
* 原理:
* CacheAutoConfiguration(selectImports方法)--->CacheConfigurations(MAPPINGS)
* --->RedisCacheConfiguration-->cacheManager方法--->RedisCacheManager初始化所有的緩存(determineConfiguration方法
* 每個(gè)緩存決定使用什么配置) --->createConfiguration方法
在config包下新建MyCacheConfig配置類
package com.atguigu.gulimall.product.config; import org.springframework.boot.autoconfigure.cache.CacheProperties; import org.springframework.cache.annotation.EnableCaching; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.cache.RedisCacheConfiguration; import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer; import org.springframework.data.redis.serializer.RedisSerializationContext; import org.springframework.data.redis.serializer.StringRedisSerializer; /** * 緩存配置 * @author zfh * @email hst1406959716@163.com * @date 2021-12-25 09:40:46 */ @EnableCaching @Configuration public class MyCacheConfig { @Bean RedisCacheConfiguration redisCacheConfiguration(){ RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig(); // config = config.entryTtl(); config = config.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer())); config = config.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer())); return config; } }
發(fā)現(xiàn)ttl變成了-1,我們的application.properties沒起作用
package com.atguigu.gulimall.product.config; import org.springframework.boot.autoconfigure.cache.CacheProperties; import org.springframework.boot.context.properties.EnableConfigurationProperties; import org.springframework.cache.annotation.EnableCaching; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.cache.RedisCacheConfiguration; import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer; import org.springframework.data.redis.serializer.RedisSerializationContext; import org.springframework.data.redis.serializer.StringRedisSerializer; /** * 緩存配置 * @author zfh * @email hst1406959716@163.com * @date 2021-12-25 09:40:46 */ @EnableConfigurationProperties(CacheProperties.class) @EnableCaching @Configuration public class MyCacheConfig { @Bean RedisCacheConfiguration redisCacheConfiguration(CacheProperties cacheProperties){ RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig(); // config = config.entryTtl(); config = config.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer())); config = config.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer())); CacheProperties.Redis redisProperties = 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(); } return config; } }
3.使用緩存前綴
在application.properties文件中
spring.cache.type=redis #spring.cache.cache-names=qq #TTL 毫秒為單位 spring.cache.redis.time-to-live=3600000 #如果指定了前綴就用我們指定的前綴,如果沒有就默認(rèn)使用緩存的名字作為前綴 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 #如果指定了前綴就用我們指定的前綴,如果沒有就默認(rèn)使用緩存的名字作為前綴 spring.cache.redis.key-prefix=CACHE_ spring.cache.redis.use-key-prefix=true #是否緩存空值,防止緩存穿透 spring.cache.redis.cache-null-values=true
代碼中直接返回null
/** * 查詢所有1級(jí)分類 * @Cacheable代表當(dāng)前方法的結(jié)果需要緩存,若緩存中有則方法不會(huì)調(diào)用,若緩存中沒有會(huì)調(diào)用方法并將結(jié)果放入緩存 * 緩存默認(rèn)行為: * a.若緩存中有則方法不會(huì)被調(diào)用 * b.key默認(rèn)自動(dòng)生成,緩存的名字::SimpleKey [] (自動(dòng)生成的key值) * c.緩存的value值,默認(rèn)使用jdk序列化機(jī)制,將序列化后的數(shù)據(jù)存到redis * d.默認(rèn)ttl時(shí)間為-1 * * 原理: * CacheAutoConfiguration(selectImports方法)--->CacheConfigurations(MAPPINGS) * --->RedisCacheConfiguration-->cacheManager方法--->RedisCacheManager初始化所有的緩存(determineConfiguration方法 * 每個(gè)緩存決定使用什么配置) --->createConfiguration方法 * @return */ // @Cacheable(value = {"category"},key ="'TopCategorys'" ) @Cacheable(value = {"category"},key ="#root.method.name" ) @Override public List<CategoryEntity> getTopCategorys() { System.out.println(".....getTopCategorys.........."); long startTime = System.currentTimeMillis(); List<CategoryEntity> categoryEntityList = this.baseMapper.selectList( new QueryWrapper<CategoryEntity>().eq("parent_cid", 0)); System.out.println("消耗時(shí)間:" + (System.currentTimeMillis() - startTime)); // return categoryEntityList; return null; }
到此這篇關(guān)于SpringCache緩存自定義配置的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)SpringCache緩存自定義配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
nacos配置注冊中心時(shí)指定命名空間不起作用的問題
這篇文章主要介紹了nacos配置注冊中心時(shí)指定命名空間不起作用的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。2022-01-01springboot集成camunda的實(shí)現(xiàn)示例
本文主要介紹了springboot集成camunda的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10MySQL查詢字段實(shí)現(xiàn)字符串分割split功能的示例代碼
本文主要介紹了MySQL查詢字段實(shí)現(xiàn)字符串分割split功能的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01Java 詳細(xì)講解線程安全與同步附實(shí)例與注釋
線程安全是多線程編程時(shí)的計(jì)算機(jī)程序代碼中的一個(gè)概念。在擁有共享數(shù)據(jù)的多條線程并行執(zhí)行的程序中,線程安全的代碼會(huì)通過同步機(jī)制保證各個(gè)線程都可以正常且正確的執(zhí)行,不會(huì)出現(xiàn)數(shù)據(jù)污染等意外情況2022-04-04SpringBoot中@Autowired爆紅原理分析及解決
這篇文章主要介紹了SpringBoot中@Autowired爆紅原理分析及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05解決Spring Cloud中Feign/Ribbon第一次請求失敗的方法
這篇文章主要給大家介紹了關(guān)于解決Spring Cloud中Feign/Ribbon第一次請求失敗的方法,文中給出了三種解決的方法,大家可以根據(jù)需要選擇對(duì)應(yīng)的方法,需要的朋友們下面來一起看看吧。2017-02-02