搜尋
首頁Javajava教程基於Java怎麼實作Redis多層緩存

一、多層快取

1. 傳統快取方案

請求到達tomcat後,先去redis中取得緩存,不命中則去mysql取得

基於Java怎麼實作Redis多層緩存

2. 多層快取方案

  • tomcat的請求並發數,是遠小於redis的,因此tomcat會變成瓶頸

  • 利用請求處理每個環節,分別加入緩存,減輕tomcat壓力,提升服務效能

基於Java怎麼實作Redis多層緩存

# #二、JVM本機快取

快取是儲存在記憶體中,資料讀取速度較快,能大幅減少對資料庫的訪問,減少資料庫壓力

##分散式緩存,如redis
 - 優點: 儲存容量大,可靠度好,可在叢集中共用

 - 缺點:存取快取有網路開銷
 - 場景: 快取資料量大,可靠度高,需要在叢集中共享的資料

進程本地緩存, 如HashMap, GuavaCache
- 優點:讀取本地內存,沒有網路開銷,速度更快

- 缺點:儲存容量有限,可靠性低(如重啟後遺失),無法在集群中共享
- 場景:效能要求高,快取資料量少

1. 實用案例

    Caffeine是一個基於java8開發的,提供了近乎最佳命中率的高效能的本機快取庫
  • 目前spring內部的快取用的就是這個
  • <dependency>
         <groupId>com.github.ben-manes.caffeine</groupId>
         <artifactId>caffeine</artifactId>
         <version>3.0.5</version>
     </dependency>
    package com.erick.cache;
    
    import com.github.benmanes.caffeine.cache.Cache;
    import com.github.benmanes.caffeine.cache.Caffeine;
    
    import java.time.Duration;
    
    public final class CacheUtil {
        private static int expireSeconds = 2;
        public static Cache<String, String> cacheWithExpireSeconds;
    
        private static int maxPairs = 1;
        public static Cache<String, String> cacheWithMaxPairs;
    
        static {
            /*过期策略,写完60s后过期*/
            cacheWithExpireSeconds = Caffeine.newBuilder()
                    .expireAfterWrite(Duration.ofSeconds(expireSeconds))
                    .build();
    
            /*过期策略,达到最大值后删除
             * 1. 并不会立即删除,等一会儿才会删除
             * 2. 会将之前存储的数据删除掉*/
            cacheWithMaxPairs = Caffeine.newBuilder()
                    .maximumSize(maxPairs)
                    .build();
        }
    
        /*从缓存中获取数据
         * 1. 如果缓存中有,则直接从缓存中返回
         * 2. 如果缓存中没有,则去数据查询并返回结果*/
        public static String getKeyWithExpire(String key) {
            return cacheWithExpireSeconds.get(key, value -> {
                return getResultFromDB();
            });
        }
    
        public static String getKeyWithMaxPair(String key) {
            return cacheWithMaxPairs.get(key, value -> {
                return getResultFromDB();
            });
        }
    
        private static String getResultFromDB() {
            System.out.println("数据库查询");
            return "db result";
        }
    }
    package com.erick.cache;
    
    import java.util.concurrent.TimeUnit;
    
    public class Test {
    
        @org.junit.Test
        public void test01() throws InterruptedException {
            CacheUtil.cacheWithExpireSeconds.put("name", "erick");
            System.out.println(CacheUtil.getKeyWithExpire("name"));
            TimeUnit.SECONDS.sleep(3);
            System.out.println(CacheUtil.getKeyWithExpire("name"));
        }
    
        @org.junit.Test
        public void test02() throws InterruptedException {
            CacheUtil.cacheWithMaxPairs.put("name", "erick");
            CacheUtil.cacheWithMaxPairs.put("age", "12");
    
            System.out.println(CacheUtil.getKeyWithMaxPair("name"));
            System.out.println(CacheUtil.getKeyWithMaxPair("age"));
    
            TimeUnit.SECONDS.sleep(2);
    
            System.out.println(CacheUtil.getKeyWithMaxPair("name")); // 查询不到了
            System.out.println(CacheUtil.getKeyWithMaxPair("age"));
        }
    }
  • 三、快取一致性

1. 常見方案

1.1 設定有效期限

    給緩存設定有效期,到期後自動刪除。再次查詢時可以更新
  • 優點:簡單,方便
  • #缺點:時效性差,快取過期之前可能不一致
  • 場景:更新頻率低,時效性需求比較低的業務
  • 1.2 同步雙寫
    在修改資料庫的同時,直接修改快取
  • 優點:有程式碼侵入,快取與資料庫強一致性
  • ##缺點:程式碼進入,耦合性高
  • 場景:對一致性,失效性要求較高的快取資料
  • 1.3 非同步通知
修改資料庫時發送事件通知,相關服務監聽到後修改快取資料
  • 優勢:低耦合,可以同時通知多個快取服務
  • 缺點:時效性一把,可能有快取不一致問題
  • 場景:時效性一般,有多個服務需要同步

基於Java怎麼實作Redis多層緩存

2. 基於Canal的非同步通知基於Java怎麼實作Redis多層緩存

是阿里旗下的一個開源項目,基於java開發
  • 基於資料庫增量日誌解析,提供增量資料訂閱和消費
  • 基於mysql的主從備份的想法
  • 2.1 mysql主從複製

#2.2 canal 工作原理基於Java怎麼實作Redis多層緩存

canal 模擬MySQL slave 的互動協議,偽裝自己為MySQL slave ,向MySQL master 發送dump 協議
  • MySQL master 收到dump 請求, 開始推送binary log 給slave (即canal )
  • canal 解析binary log 物件(原始為byte 流)
  • #

以上是基於Java怎麼實作Redis多層緩存的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:亿速云。如有侵權,請聯絡admin@php.cn刪除
曲線積分變量替換:如何將$\int_0^1 \frac{y^2}{\sqrt{1-y^2}}dy$轉化為$\int_0^{\frac{\pi}{2}}\sin^2tdt$?曲線積分變量替換:如何將$\int_0^1 \frac{y^2}{\sqrt{1-y^2}}dy$轉化為$\int_0^{\frac{\pi}{2}}\sin^2tdt$?Apr 19, 2025 pm 03:03 PM

關於曲線積分中變量替換的疑問本文將針對一個曲線積分計算中變量替換的步驟進行詳細解釋。提問者在計算一...

微信小程序申請:流程、費用及與服務號的關係詳解?微信小程序申請:流程、費用及與服務號的關係詳解?Apr 19, 2025 pm 03:00 PM

微信小程序申請流程及費用詳解朋友委託開發微信小程序商城,在申請過程中遇到一些關於費用和流程的問題,...

Java緩存數據丟失:為何從緩存中無法獲取數據?Java緩存數據丟失:為何從緩存中無法獲取數據?Apr 19, 2025 pm 02:57 PM

Java緩存數據無法獲取的原因分析及優化方案在Java項目中,將大量數據緩存到內存中以便快速訪問是一個常見的�...

想成為更優秀的Java開發者,深入研究JVM的哪些方面最值得投入?
或
Java進階:深入研究JVM,哪些核心機制最值得探索?想成為更優秀的Java開發者,深入研究JVM的哪些方面最值得投入? 或 Java進階:深入研究JVM,哪些核心機制最值得探索?Apr 19, 2025 pm 02:54 PM

深入Java:值得探索的虛擬機世界很多Java開發者在掌握了基礎語法和常用框架後,都希望進一步提升自己的技術�...

使用EasyExcel填充Excel模板時,如何解決合併單元格的數據覆蓋和样式丟失問題?使用EasyExcel填充Excel模板時,如何解決合併單元格的數據覆蓋和样式丟失問題?Apr 19, 2025 pm 02:51 PM

EasyExcel模板填充合併單元格時的常見問題在使用EasyExcel進行Excel...

系統對接中的字段映射如何通過MapStruct工具高效解決?系統對接中的字段映射如何通過MapStruct工具高效解決?Apr 19, 2025 pm 02:48 PM

系統對接中的字段映射挑戰及其解決方案在系統對接過程中,經常會遇到需要將一個系統的接口字段映射到另一...

SpringBoot應用中PgJDBC連接池拋出'PSQLException: ERROR: canceling statement due to user request”異常該如何解決?SpringBoot應用中PgJDBC連接池拋出'PSQLException: ERROR: canceling statement due to user request”異常該如何解決?Apr 19, 2025 pm 02:45 PM

SpringBoot應用中PgJDBC連接池拋出PSQLException:ERROR:cancelingstatementduetouserrequest異常在使用SpringBoot MyBatis-Plus ...

如何設計抽獎算法才能確保不虧損?如何設計抽獎算法才能確保不虧損?Apr 19, 2025 pm 02:42 PM

如何設計抽獎算法以保證不虧損?在設計一個抽獎產品時,如何設置每個獎品的中獎概率是一個關鍵問題。假設...

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱工具

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。