成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Spring Cache 緩存注解這樣用,實在是太香了!

開發 前端
Spring Cache? 框架給我們提供了 @Cacheable? 注解用于緩存方法返回內容。但是 @Cacheable 注解不能定義緩存有效期。這樣的話在一些需要自定義緩存有效期的場景就不太實用。

作者最近在開發公司項目時使用到 Redis 緩存,并在翻看前人代碼時,看到了一種關于 @Cacheable 注解的自定義緩存有效期的解決方案,感覺比較實用,因此作者自己拓展完善了一番后分享給各位。

Spring 緩存常規配置

Spring Cache 框架給我們提供了 @Cacheable 注解用于緩存方法返回內容。但是 @Cacheable 注解不能定義緩存有效期。這樣的話在一些需要自定義緩存有效期的場景就不太實用。

按照 Spring Cache 框架給我們提供的 RedisCacheManager 實現,只能在全局設置緩存有效期。這里給大家看一個常規的 CacheConfig 緩存配置類,代碼如下,

@EnableCaching
@Configuration
public class CacheConfig extends CachingConfigurerSupport {
    ...

    private RedisSerializer<String> keySerializer() {
        return new StringRedisSerializer();
    }

    private RedisSerializer<Object> valueSerializer() {
        return new GenericFastJsonRedisSerializer();
    }

    public static final String CACHE_PREFIX = "crowd:";

    @Bean
    public CacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
        // 配置序列化(解決亂碼的問題)
        RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
                //設置key為String
                .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(keySerializer()))
                //設置value為自動轉Json的Object
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(valueSerializer()))
                .computePrefixWith(name -> CACHE_PREFIX + name  + ":")
                .entryTtl(Duration.ofSeconds(600));
        RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(Objects.requireNonNull(redisConnectionFactory));
        return new RedisCacheManager(redisCacheWriter, config);
    }
}

這里面簡單對 RedisCacheConfiguration 緩存配置做一下說明:

  1. serializeKeysWith():設置 Redis 的 key 的序列化規則。
  2. erializeValuesWith():設置 Redis 的 value 的序列化規則。
  3. computePrefixWith():計算 Redis 的 key 前綴。
  4. entryTtl():全局設置 @Cacheable 注解緩存的有效期。

那么使用如上配置生成的 Redis 緩存 key 名稱是什么樣得嘞?這里用開源項目 crowd-admin 的 ConfigServiceImpl 類下 getValueByKey(String key) 方法舉例,

@Cacheable(value = "configCache", key = "#root.methodName + '_' + #root.args[0]")
@Override
public String getValueByKey(String key) {
    QueryWrapper<Config> wrapper = new QueryWrapper<>();
    wrapper.eq("configKey", key);
    Config config = getOne(wrapper);
    if (config == null) {
        return null;
    }
    return config.getConfigValue();
}

執行此方法后,Redis 中緩存 key 名稱如下,

crowd:configCache:getValueByKey_sys.name

圖片圖片

TTL 過期時間是 287,跟我們全局設置的 300 秒基本是一致的。此時假如我們想把 getValueByKey 方法的緩存有效期單獨設置為 600 秒,那我們該如何操作嘞?

@Cacheable 注解默認是沒有提供有關緩存有效期設置的。想要單獨修改 getValueByKey 方法的緩存有效期只能修改全局的緩存有效期。那么有沒有別的方法能夠為 getValueByKey 方法單獨設置緩存有效期嘞?當然是有的,大家請往下看。

自定義 MyRedisCacheManager 緩存

其實我們可以通過自定義 MyRedisCacheManager 類繼承 Spring Cache 提供的 RedisCacheManager 類后,重寫 createRedisCache(String name, RedisCacheConfiguration cacheConfig) 方法,代碼如下,

public class MyRedisCacheManager extends RedisCacheManager {
    public MyRedisCacheManager(RedisCacheWriter cacheWriter, RedisCacheConfiguration defaultCacheConfiguration) {
        super(cacheWriter, defaultCacheConfiguration);
    }

    @Override
    protected RedisCache createRedisCache(String name, RedisCacheConfiguration cacheConfig) {
        String[] array = StringUtils.split(name, "#");
        name = array[0];
         // 解析 @Cacheable 注解的 value 屬性用以單獨設置有效期
        if (array.length > 1) {
            long ttl = Long.parseLong(array[1]);
            cacheConfig = cacheConfig.entryTtl(Duration.ofSeconds(ttl));
        }
        return super.createRedisCache(name, cacheConfig);
    }
}

MyRedisCacheManager 類邏輯如下,

  1. 繼承 Spring Cache 提供的 RedisCacheManager 類。
  2. 重寫 createRedisCache(String name, RedisCacheConfiguration cacheConfig) 方法。
  3. 解析 name 參數,根據 # 字符串進行分割,獲取緩存 key 名稱以及緩存有效期。

接著我們修改下 CacheConfig 類的 cacheManager 方法用以使用 MyRedisCacheManager 類。代碼如下,

@Bean
public CacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
    return new MyRedisCacheManager(RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory), defaultCacheConfig());
}

private RedisCacheConfiguration defaultCacheConfig() {
    return RedisCacheConfiguration.defaultCacheConfig()
            .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(keySerializer()))
            .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(valueSerializer()))
            .computePrefixWith(name -> CACHE_PREFIX + name  + ":")
            .entryTtl(Duration.ofSeconds(600));
}

最后我們修改下 @Cacheable 注解使用方式,在原有 value 屬性的 configCache 值后添加 #600,單獨標識緩存有效期。代碼如下,

@Cacheable(value = "configCache#600", key = "#root.methodName + '_' + #root.args[0]")
@Override
public String getValueByKey(String key) {
   ...
}

看下 getValueByKey 方法生成的 Redis 緩存 key 有效期是多久。如下,

圖片圖片

OK,看到是 590 秒有效期后,我們就大功告成了,希望本文能對大家有所幫助??????。

責任編輯:武曉燕 來源: waynblog
相關推薦

2020-10-10 11:07:38

Java開發代碼

2024-01-26 07:48:10

SpringKafka提升

2024-01-05 13:26:00

KafkaTopicSpring

2020-12-21 07:36:15

緩存數據庫緩存層

2020-09-09 09:55:36

JavaNIOBIO

2025-04-25 08:11:29

2021-08-02 19:18:32

Redis緩存高并發

2021-12-03 10:46:49

ELKGraylog運維

2021-07-28 14:20:13

正則PythonFlashText

2021-12-02 06:34:34

GraylogELK日志

2020-03-23 08:30:12

程序員男友感受

2023-11-07 10:36:37

2023-05-05 18:38:33

多級緩存Caffeine開發

2021-06-29 19:26:29

緩存Spring CachSpring

2023-10-30 07:56:46

Spring緩存

2025-02-05 14:28:19

2023-11-13 22:47:58

PythonPathlib

2025-01-09 11:24:59

線程池美團動態配置中心

2024-11-25 13:49:00

2024-08-09 08:55:43

if執行器版本
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产欧美日韩精品一区 | 欧美一区日韩一区 | 精品综合网 | 五月婷婷色 | 国产美女在线观看 | 欧美精品成人一区二区三区四区 | 国产精品久久免费观看 | 亚洲黄色av | 亚洲精品888 | 波多野结衣中文字幕一区二区三区 | 国产高清久久 | 伊人激情网 | 久久久国产精品视频 | 天天躁天天操 | 色综合久久久久 | 欧美综合久久 | 欧美日一区二区 | 国产成人精品久久二区二区91 | 呦呦在线视频 | 久久久综合网 | 国产高清精品在线 | 91免费看片| 精品美女视频在免费观看 | h片在线免费看 | 国产成人精品a视频一区www | 午夜视频导航 | 欧美高清视频在线观看 | 亚洲精品毛片av | 妖精视频一区二区三区 | 少妇精品久久久久久久久久 | 99精品久久 | 精品欧美一区二区三区 | 国产精品久久久久久久7电影 | 日韩视频在线观看一区二区 | 特黄特色大片免费视频观看 | 欧美精品一区二区三区在线四季 | 粉嫩av在线 | 久久久久国产一区二区三区 | 欧美精品久久 | 日韩在线播放中文字幕 | 久久久久一区 |