SpringCache 分布式緩存的實現(xiàn)方法(規(guī)避redis解鎖的問題)
簡介
spring 從3.1 開始定義
- org.springframework.cache.Cache
- org.springframework.cache.CacheManager
來統(tǒng)一不同的緩存技術(shù)
并支持使用JCache(JSR-107)注解簡化我們的開發(fā)

基礎(chǔ)概念

實戰(zhàn)使用
整合SpringCache簡化緩存開發(fā)
常用注解
| 常用注解 | 說明 |
|---|---|
| @CacheEvict | 觸發(fā)將數(shù)據(jù)從緩存刪除的操作 (失效模式) |
| @CachePut | 不影響方法執(zhí)行更新緩存 |
| @Caching | 組合以上多個操作 |
| @CacheConfig | 在類級別共享緩存的相同配置 |
| @Cacheable | 觸發(fā)將數(shù)據(jù)保存到緩存的操作 |
方法
1)、開啟緩存功能 @EnableCaching
2)、只需要使用注解就能完成緩存操作
1、引入依賴
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、寫配置
在項目新建config文件夾,新建一個config類

代碼如下:
@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)、自動配置寫了哪些 CacheAutoConfiguration 會導入 RedisAutoConfiguration 自動配置好緩存管理器RedisCacheManager (2)、配置使用redis做為緩存 spring.cache.typeredis
3、修改pom 配置
spring: cache: type: redis redis: # 緩存過期時間 time-to-live: 60000 # 如果制定了前綴,我們就是用指定的前綴,如果沒有我們就默認使用緩存的名字作為前綴 key-prefix: CACHE_ # 是否使用前綴 use-key-prefix: true # 是否把緩存空值,防止緩存穿透 cache-null-values: true
4、原理

1、每一個要緩存的數(shù)據(jù) 我們都來指定要放到那個名字的緩存【緩存的分區(qū)(按照業(yè)務(wù)類型)】
2、@cacheable({"category"})
代表當前方法的結(jié)果需要緩存,如果緩存中,方法不用調(diào)用
如果緩存中沒有,會調(diào)用方法,最后將方法的結(jié)果放入緩存
3、默認行為
1)、如果緩存中有,方法不用調(diào)用
2)、key默認自動生成:緩存的名字::SimpleKey[] (自主生成的key值)
3)、緩存的value的值。默認使用jdk序列化機制,將序列化后的數(shù)據(jù)存到redis
4)、默認 ttl 時間 -1 (永不過期)
自定義:
1)、指定生成的緩存使用的key: key屬性制定,接受一個SpEL
SpEL(詳見文檔)
2)、指定緩存的數(shù)據(jù)的存活時間:配置文件中修改 ttl
3)、將數(shù)據(jù)保存為 json 格式:
自定義 RedisCacheConfiguration即可
失效模式:@CacheEvict
原理:變更緩存的時候會將redis中的緩存刪除
(當下次查詢時,會重新載入緩存)

推薦使用@CacheEvict
同時進行多種緩存操作 @Caching指定刪除某個分區(qū)下的所有數(shù)據(jù)
@CacheEvict(value=“category”,allEntries=true)存儲統(tǒng)一類型的數(shù)據(jù),都可以指定成同一個分區(qū)。分區(qū)名默認就是緩存的前綴
類中使用:@CacheEvict(value=“category”,allEntries=true)
配置中使用:(禁用前綴 + 默認前綴)
spring.cache.redis.use-key-prefix=true

雙寫模式:@CachePut
原理:在變更緩存時,刪除原有的緩存,然后將新數(shù)據(jù)重新插入到緩存中
到此這篇關(guān)于SpringCache 分布式緩存(規(guī)避redis解鎖的問題)的文章就介紹到這了,更多相關(guān)SpringCache 分布式緩存內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
IDEA 程序包不存在,找不到符號但是明明存在對應的jar包(問題分析及解決方案)
這篇文章主要介紹了IDEA 程序包不存在,找不到符號但是明明存在對應的jar包 的解決方案,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-08
kafka topic 權(quán)限控制(設(shè)置刪除權(quán)限)
大家都知道Kafka是一個消息隊列,把消息放到隊列里邊的叫生產(chǎn)者,從隊列里邊消費的叫消費者。今天通過本文給大家介紹kafka topic 權(quán)限控制的相關(guān)知識,感興趣的朋友一起看看吧2021-11-11
Java實現(xiàn)解析dcm醫(yī)學影像文件并提取文件信息的方法示例
這篇文章主要介紹了Java實現(xiàn)解析dcm醫(yī)學影像文件并提取文件信息的方法,結(jié)合實例形式分析了java基于第三方庫文件針對dcm醫(yī)學影像文件的解析操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2018-04-04
Java編程synchronized與lock的區(qū)別【推薦】
互聯(lián)網(wǎng)信息泛濫環(huán)境下少有的良心之作!如果您想對Java編程synchronized與lock的區(qū)別有所了解,這篇文章絕對值得!分享給大家,供需要的朋友參考。不說了,我先學習去了。2017-10-10

