您好,登錄后才能下訂單哦!
分布式緩存如何在SpringCache 項目中實現?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
spring 從3.1 開始定義
并支持使用JCache(JSR-107)注解簡化我們的開發
基礎概念
實戰使用
整合SpringCache簡化緩存開發
常用注解
常用注解 | 說明 |
---|---|
@CacheEvict | 觸發將數據從緩存刪除的操作 (失效模式) |
@CachePut | 不影響方法執行更新緩存 |
@Caching | 組合以上多個操作 |
@CacheConfig | 在類級別共享緩存的相同配置 |
@Cacheable | 觸發將數據保存到緩存的操作 |
方法
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容器中放參數 @EnableCaching @Configuration public class MyCacheConfig { /** * 配置文件中的內容不再生效(全部走自定義配置) * @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、每一個要緩存的數據 我們都來指定要放到那個名字的緩存【緩存的分區(按照業務類型)】 2、@cacheable({"category"}) 代表當前方法的結果需要緩存,如果緩存中,方法不用調用 如果緩存中沒有,會調用方法,最后將方法的結果放入緩存 3、默認行為 1)、如果緩存中有,方法不用調用 2)、key默認自動生成:緩存的名字::SimpleKey[] (自主生成的key值) 3)、緩存的value的值。默認使用jdk序列化機制,將序列化后的數據存到redis 4)、默認 ttl 時間 -1 (永不過期) 自定義: 1)、指定生成的緩存使用的key: key屬性制定,接受一個SpEL SpEL(詳見文檔) 2)、指定緩存的數據的存活時間:配置文件中修改 ttl 3)、將數據保存為 json 格式: 自定義 RedisCacheConfiguration即可
失效模式:@CacheEvict
原理:變更緩存的時候會將redis中的緩存刪除
(當下次查詢時,會重新載入緩存)
推薦使用@CacheEvict
同時進行多種緩存操作 @Caching指定刪除某個分區下的所有數據
@CacheEvict(value=“category”,allEntries=true)存儲統一類型的數據,都可以指定成同一個分區。分區名默認就是緩存的前綴
類中使用:@CacheEvict(value=“category”,allEntries=true)
配置中使用:(禁用前綴 + 默認前綴)
spring.cache.redis.use-key-prefix=true
雙寫模式:@CachePut
原理:在變更緩存時,刪除原有的緩存,然后將新數據重新插入到緩存中
看完上述內容,你們掌握分布式緩存如何在SpringCache 項目中實現的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。