中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

分布式緩存如何在SpringCache 項目中實現

發布時間:2020-11-20 14:34:44 來源:億速云 閱讀:453 作者:Leah 欄目:開發技術

分布式緩存如何在SpringCache 項目中實現?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

spring 從3.1 開始定義

  •  org.springframework.cache.Cache
  • org.springframework.cache.CacheManager
       來統一不同的緩存技術

并支持使用JCache(JSR-107)注解簡化我們的開發

分布式緩存如何在SpringCache 項目中實現

基礎概念

分布式緩存如何在SpringCache 項目中實現

實戰使用

整合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類

分布式緩存如何在SpringCache 項目中實現

代碼如下:

@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、原理

分布式緩存如何在SpringCache 項目中實現

 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中的緩存刪除
(當下次查詢時,會重新載入緩存)

分布式緩存如何在SpringCache 項目中實現

推薦使用@CacheEvict

同時進行多種緩存操作 @Caching指定刪除某個分區下的所有數據
@CacheEvict(value=“category”,allEntries=true)存儲統一類型的數據,都可以指定成同一個分區。分區名默認就是緩存的前綴

類中使用:@CacheEvict(value=“category”,allEntries=true)
配置中使用:(禁用前綴 + 默認前綴)
spring.cache.redis.use-key-prefix=true

分布式緩存如何在SpringCache 項目中實現

雙寫模式:@CachePut

原理:在變更緩存時,刪除原有的緩存,然后將新數據重新插入到緩存中

看完上述內容,你們掌握分布式緩存如何在SpringCache 項目中實現的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

清流县| 淅川县| 花垣县| 永康市| 桂东县| 无棣县| 双鸭山市| 乌拉特后旗| 张掖市| 通化县| 奇台县| 城固县| 托里县| 广安市| 永安市| 琼结县| 弋阳县| 巨野县| 黄梅县| 青海省| 赣榆县| 仙桃市| 察雅县| 通州区| 奉贤区| 枣强县| 时尚| 台北市| 曲水县| 灵石县| 齐齐哈尔市| 富宁县| 西吉县| 察哈| 岑溪市| 贵溪市| 石家庄市| 边坝县| 肥城市| 鸡西市| 利川市|