欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring?Boot?緩存?與?Redis問題小結

 更新時間:2025年07月21日 09:56:30   作者:黃名富  
本文總結SpringBoot緩存方案,對比Redis與EnCache優(yōu)劣,指出Redis支持集群但效率較低,EnCache速度快但不支持分布式,SpringBoot默認使用ConcurrentHashMapManager,本文給大家介紹Spring?Boot緩存與Redis問題小結,感興趣的朋友一起看看吧

緩存是提升接口響應速度和降低數(shù)據(jù)庫壓力的重要手段。

Redis

通過Socket訪問到緩存服務,效率比EnCache低,對集群和分布式支持友好。

EnCache

純Java的進程緩存,直接在JVM中進行緩存,速度快、效率高,但對分布式集群的支持不太好。

ConcurrentHashMap

Manager

Spring Boot 默認提供的緩存管理器,線程安全,官方明確不建議在生產(chǎn)環(huán)境使用。

表 Java緩存方案對比

1 緩存注解

Spring Boot 提供了緩存抽象層,并結合JSR-107標準,提供了多個緩存注解。

@Cacheable

查詢緩存。

@CachePut

更新緩存。

@CacheEvict

刪除緩存。

表 常用的緩存注解

這些注解作用于方法級別,在不侵入業(yè)務邏輯的前提下,實現(xiàn)緩存管理。它們是基于AOP實現(xiàn)的,有以下注意項:

  1. 只能用于public方法上。
  2. 只有當調(diào)用方通過Spring代理調(diào)用該方法時才生效。(同一個類中直接調(diào)用不生效)
  3. 需要啟用緩存功能。@EnableCaching。

1.1 緩存key 生成策略

緩存注解keyGenerator字段用于指定該方法緩存key的生成策略。

圖 key 生成策略需實現(xiàn)的接口

    @Bean
    public KeyGenerator paramsKeyGenerator() {
        return ((target, method, params) -> {
           StringBuilder sb = new StringBuilder();
           sb.append(target.getClass().getSimpleName());
           sb.append("::");
           sb.append(method.getName());
           for (Object obj : params) {
               sb.append("::");
               sb.append(obj.toString());
           }
           return sb.toString();
        });
    }

2 Redis 緩存策略

maven依賴:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

緩存策略配置:

@Configuration
@EnableCaching
public class CacheConfig {
    @Bean
    public CacheManager cacheManager(RedisConnectionFactory factory) {
        RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofMinutes(30))
                .disableCachingNullValues() // 避免緩存穿透
                .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer()))
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer()));
        return RedisCacheManager.builder(factory)
                .cacheDefaults(config)
                .build();
    }
}

2.1 redis 連接池

Spring Boot 2.x 默認使用Lettuce作為Redis客戶端。

Lettuce

基于Netty的異步非阻塞通信;原生線程安全;長連接Lettuce性能優(yōu)勢更明顯;CPU利用率更高效。

Jedis

同步阻塞通信;非線程安全;

表 Lettuce 與 Jedis對比

2.2 Redis 緩存問題

1 緩存穿透:查詢一個根本不存在的數(shù)據(jù),導致每次查詢都會訪問數(shù)據(jù)庫。

使用布隆過濾器(檢索元素是否存在集合中)。它內(nèi)存占用小。判斷元素存在有誤差,但是判斷元素不存在絕對準確。

2 緩存擊穿:某個熱點key突然實現(xiàn),大量請求同時訪問時,會擊穿緩存直接訪問數(shù)據(jù)庫。

使用互斥鎖或邏輯過期。也可以設置熱點key永不過期或是后臺刷新熱點key緩存。

3 緩存雪崩:大量緩存key同時失效,大量請求直接訪問數(shù)據(jù)庫。發(fā)生場景有:1)緩存服務器重啟;2)大量緩存設置相同過期時間。

緩存key的過期時間隨機化。

到此這篇關于Spring Boot 緩存 與 Redis的文章就介紹到這了,更多相關Spring Boot 緩存 Redis內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Redis大key多key拆分實現(xiàn)方法解析

    Redis大key多key拆分實現(xiàn)方法解析

    這篇文章主要介紹了Redis大key多key拆分實現(xiàn)方法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-11-11
  • 無法啟動Redis打開redis-server閃退的問題解決辦法

    無法啟動Redis打開redis-server閃退的問題解決辦法

    正常開啟redis服務,首先要啟動redis-server.exe,但是閃退,導致無法開啟redis服務,這篇文章主要給大家介紹了關于無法啟動Redis打開redis-server閃退問題的解決辦法,需要的朋友可以參考下
    2024-07-07
  • Redis分片集群的實現(xiàn)

    Redis分片集群的實現(xiàn)

    Redis 分片集群是一種將 Redis數(shù)據(jù)庫分散到多個節(jié)點上的方式,以提供更高的性能和可伸縮性,本文主要介紹了Redis分片集群的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2025-04-04
  • 淺談redission鎖的默認失效時間

    淺談redission鎖的默認失效時間

    Redisson是一個基于Redis的Java駐留庫,提供了許多分布式對象和服務,包括分布式鎖,本文主要介紹了淺談redission鎖的默認失效時間, 具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • Redis分布式鎖解決秒殺超賣問題

    Redis分布式鎖解決秒殺超賣問題

    本文主要介紹了Redis分布式鎖解決秒殺超賣問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • Redis中統(tǒng)計各種數(shù)據(jù)大小的方法

    Redis中統(tǒng)計各種數(shù)據(jù)大小的方法

    這篇文章主要介紹了Redis中統(tǒng)計各種數(shù)據(jù)大小的方法,本文使用PHP實現(xiàn)統(tǒng)計Redis內(nèi)存占用比較大的鍵,需要的朋友可以參考下
    2015-03-03
  • Redis實現(xiàn)數(shù)據(jù)的交集、并集、補集的示例

    Redis實現(xiàn)數(shù)據(jù)的交集、并集、補集的示例

    本文主要介紹了Redis實現(xiàn)數(shù)據(jù)的交集、并集、補集的示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08
  • 解決redis-cli報錯Could not connect to Redis at 127.0.0.1:6379: Connection refused

    解決redis-cli報錯Could not connect to Redis&

    這篇文章主要介紹了解決redis-cli報錯Could not connect to Redis at 127.0.0.1:6379: Connection refused,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-04-04
  • 一文詳解Redis為什么一定要設置密碼原理

    一文詳解Redis為什么一定要設置密碼原理

    這篇文章主要為大家介紹了Redis為什么一定要設置密碼原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • 詳解Redis中的雙鏈表結構

    詳解Redis中的雙鏈表結構

    這篇文章主要介紹了Redis中的雙鏈表結構,包括listNode結構的API,需要的朋友可以參考下
    2015-08-08

最新評論