SpringCache 分布式緩存的實(shí)現(xiàn)方法(規(guī)避redis解鎖的問(wèn)題)
簡(jiǎn)介
spring 從3.1 開(kāi)始定義
- org.springframework.cache.Cache
- org.springframework.cache.CacheManager
來(lái)統(tǒng)一不同的緩存技術(shù)
并支持使用JCache(JSR-107)注解簡(jiǎn)化我們的開(kāi)發(fā)
基礎(chǔ)概念
實(shí)戰(zhàn)使用
整合SpringCache簡(jiǎn)化緩存開(kāi)發(fā)
常用注解
常用注解 | 說(shuō)明 |
---|---|
@CacheEvict | 觸發(fā)將數(shù)據(jù)從緩存刪除的操作 (失效模式) |
@CachePut | 不影響方法執(zhí)行更新緩存 |
@Caching | 組合以上多個(gè)操作 |
@CacheConfig | 在類(lèi)級(jí)別共享緩存的相同配置 |
@Cacheable | 觸發(fā)將數(shù)據(jù)保存到緩存的操作 |
方法
1)、開(kāi)啟緩存功能 @EnableCaching
2)、只需要使用注解就能完成緩存操作
1、引入依賴(lài)
spring-boot-starter-cache、spring-boot-starter-data-redis
配合redis使用
<!-- 引入 redis--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> <!-- 排除 lettuce --> <exclusions> <exclusion> <groupId>io.lettuce</groupId> <artifactId>lettuce-core</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-cache</artifactId> </dependency>
2、寫(xiě)配置
在項(xiàng)目新建config文件夾,新建一個(gè)config類(lèi)
代碼如下:
@EnableConfigurationProperties(CacheProperties.class)//為configuration容器中放參數(shù) @EnableCaching @Configuration public class MyCacheConfig { /** * 配置文件中的內(nèi)容不再生效(全部走自定義配置) * @param cacheProperties * @return */ @Bean RedisCacheConfiguration redisCacheConfiguration(CacheProperties cacheProperties){ RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig(); 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.prefixCacheNameWith(redisProperties.getKeyPrefix()); } if (!redisProperties.isCacheNullValues()) { config = config.disableCachingNullValues(); } if (!redisProperties.isUseKeyPrefix()) { config = config.disableKeyPrefix(); } return config; } }
(1)、自動(dòng)配置寫(xiě)了哪些 CacheAutoConfiguration 會(huì)導(dǎo)入 RedisAutoConfiguration 自動(dòng)配置好緩存管理器RedisCacheManager (2)、配置使用redis做為緩存 spring.cache.typeredis
3、修改pom 配置
spring: cache: type: redis redis: # 緩存過(guò)期時(shí)間 time-to-live: 60000 # 如果制定了前綴,我們就是用指定的前綴,如果沒(méi)有我們就默認(rèn)使用緩存的名字作為前綴 key-prefix: CACHE_ # 是否使用前綴 use-key-prefix: true # 是否把緩存空值,防止緩存穿透 cache-null-values: true
4、原理
1、每一個(gè)要緩存的數(shù)據(jù) 我們都來(lái)指定要放到那個(gè)名字的緩存【緩存的分區(qū)(按照業(yè)務(wù)類(lèi)型)】 2、@cacheable({"category"}) 代表當(dāng)前方法的結(jié)果需要緩存,如果緩存中,方法不用調(diào)用 如果緩存中沒(méi)有,會(huì)調(diào)用方法,最后將方法的結(jié)果放入緩存 3、默認(rèn)行為 1)、如果緩存中有,方法不用調(diào)用 2)、key默認(rèn)自動(dòng)生成:緩存的名字::SimpleKey[] (自主生成的key值) 3)、緩存的value的值。默認(rèn)使用jdk序列化機(jī)制,將序列化后的數(shù)據(jù)存到redis 4)、默認(rèn) ttl 時(shí)間 -1 (永不過(guò)期) 自定義: 1)、指定生成的緩存使用的key: key屬性制定,接受一個(gè)SpEL SpEL(詳見(jiàn)文檔) 2)、指定緩存的數(shù)據(jù)的存活時(shí)間:配置文件中修改 ttl 3)、將數(shù)據(jù)保存為 json 格式: 自定義 RedisCacheConfiguration即可
失效模式:@CacheEvict
原理:變更緩存的時(shí)候會(huì)將redis中的緩存刪除
(當(dāng)下次查詢(xún)時(shí),會(huì)重新載入緩存)
推薦使用@CacheEvict
同時(shí)進(jìn)行多種緩存操作 @Caching指定刪除某個(gè)分區(qū)下的所有數(shù)據(jù)
@CacheEvict(value=“category”,allEntries=true)存儲(chǔ)統(tǒng)一類(lèi)型的數(shù)據(jù),都可以指定成同一個(gè)分區(qū)。分區(qū)名默認(rèn)就是緩存的前綴
類(lèi)中使用:@CacheEvict(value=“category”,allEntries=true)
配置中使用:(禁用前綴 + 默認(rèn)前綴)
spring.cache.redis.use-key-prefix=true
雙寫(xiě)模式:@CachePut
原理:在變更緩存時(shí),刪除原有的緩存,然后將新數(shù)據(jù)重新插入到緩存中
到此這篇關(guān)于SpringCache 分布式緩存(規(guī)避redis解鎖的問(wèn)題)的文章就介紹到這了,更多相關(guān)SpringCache 分布式緩存內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
datax-web在windows環(huán)境idea中模塊化打包部署操作步驟
這篇文章主要介紹了datax-web在windows環(huán)境idea中模塊化打包部署操作步驟,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-05-05SpringBoot項(xiàng)目在IntelliJ IDEA中如何實(shí)現(xiàn)熱部署
spring-boot-devtools是一個(gè)為開(kāi)發(fā)者服務(wù)的一個(gè)模塊,其中最重要的功能就是自動(dòng)應(yīng)用代碼更改到最新的App上面去。,這篇文章主要介紹了SpringBoot項(xiàng)目在IntelliJ IDEA中如何實(shí)現(xiàn)熱部署,感興趣的小伙伴們可以參考一下2018-07-07java中MultipartFile互轉(zhuǎn)File的方法
本文主要介紹了java中MultipartFile互轉(zhuǎn)File的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10springboot schedule 解決定時(shí)任務(wù)不執(zhí)行的問(wèn)題
這篇文章主要介紹了springboot schedule 解決定時(shí)任務(wù)不執(zhí)行的問(wèn)題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09Java使用icepdf將pdf文件按頁(yè)轉(zhuǎn)成圖片
這篇文章主要為大家詳細(xì)介紹了Java使用icepdf將pdf文件按頁(yè)轉(zhuǎn)成圖片,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12Java用split分割含一個(gè)或多個(gè)空格的字符串案例
這篇文章主要介紹了Java用split分割含一個(gè)或多個(gè)空格的字符串案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)過(guò)來(lái)看看吧2020-09-09