保證mysql和redis的雙寫一致性
一、情境:
雙寫一致性指的是當我們更新了資料庫的資料之後redis中的資料 也要同步去更新。使用redis讀取資料的流程,當用戶存取資料的時候,會先從快取中讀取數據,如果命中快取的話,那麼直接把快取中的資料傳回給用戶,如果快取中沒有資料的話,先查詢資料庫把查詢到的資料儲存到快取中,然後回傳給使用者。
二、保證雙寫一致性的策略
1、先更新緩存,再更新資料庫
2、先更新資料庫,再更新快取
3、先刪除緩存,再更新資料庫
4、先更新資料庫,再刪除快取
三,四種策略的優缺點
1、先更新緩存,再更新資料庫
問題很明顯若更新快取成功,更新資料庫失敗,就會造成快取的髒資料
2、先更新資料庫,再更新快取
如果再高並發的情況下,可能會存在如下的情況,線程A更新了資料庫,如果由於網路或其他的原因,線程A還來不及更新緩存,這時候有一個進程B更新了資料庫,更新了緩存,這時候進程A才更新緩存,這時候就會導致線程B對緩存的更新丟失了,像事務丟失的情況
3、先刪除緩存,再更新資料庫
這種策略可能已經避免掉了,策略2中快取遺失的情況,但是再高並發的情況下,也會有不一致的情況,例如線程A做寫操作,首先刪除緩存然後準備跟新資料庫,這時候,線程B執行了寫入操作,沒有命中緩存,然後查詢資料庫,這時候讀取的是舊值,並把查詢到的舊值保存到快取中,接著線程A完成了資料庫的更新,這時候資料庫和快取又出現了不一致的情況,解決方案:我們只要再線程A,完成資料庫的更新之後,稍作延遲再刪除一次緩存,也叫做延遲雙刪。這裡的延遲時間一定大於業務的一次讀取操作的時間。
4、先更新資料庫,再刪除快取
再高並發的情況下,也會有不一致的情況,例如執行緒A做讀取資料的操作,正準備寫入快取的時候,線程B更新了資料庫,然後執行了刪除快取的操作,這時候線程A才把舊值寫入到快取中,雖然這種情況出現的機率比較低,因為寫入操作的時候要大於一次讀取操作的時間的。解決方案:延遲雙刪,延時雙刪還是又問題的,如果刪除快取失敗怎麼辦,當然是再次刪除,不斷的循環刪除。刪除失敗後我們可以將要刪除的key放入到佇列中,然後嘗試重複刪除,直到刪除成功。
以上是保證mysql和redis的雙寫一致性的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

MySQL和phpMyAdmin是強大的數據庫管理工具。 1)MySQL用於創建數據庫和表、執行DML和SQL查詢。 2)phpMyAdmin提供直觀界面進行數據庫管理、表結構管理、數據操作和用戶權限管理。

Redis緩存方案如何實現產品排行榜列表的需求?在開發過程中,我們常常需要處理排行榜的需求,例如展示一個�...

Redis在數據存儲和管理中扮演著關鍵角色,通過其多種數據結構和持久化機製成為現代應用的核心。 1)Redis支持字符串、列表、集合、有序集合和哈希表等數據結構,適用於緩存和復雜業務邏輯。 2)通過RDB和AOF兩種持久化方式,Redis確保數據的可靠存儲和快速恢復。

在MySQL中,外鍵的作用是建立表與表之間的關係,確保數據的一致性和完整性。外鍵通過引用完整性檢查和級聯操作維護數據的有效性,使用時需注意性能優化和避免常見錯誤。

MySQL和MariaDB的主要區別在於性能、功能和許可證:1.MySQL由Oracle開發,MariaDB是其分支。 2.MariaDB在高負載環境中性能可能更好。 3.MariaDB提供了更多的存儲引擎和功能。 4.MySQL採用雙重許可證,MariaDB完全開源。選擇時應考慮現有基礎設施、性能需求、功能需求和許可證成本。

SQL是一種用於管理關係數據庫的標準語言,而MySQL是一個使用SQL的數據庫管理系統。 SQL定義了與數據庫交互的方式,包括CRUD操作,而MySQL實現了SQL標準並提供了額外的功能,如存儲過程和触發器。

Redis是一种内存数据结构存储系统,主要用作数据库、缓存和消息代理。它的核心特点包括单线程模型、I/O多路复用、持久化机制、复制与集群功能。Redis在实际应用中常用于缓存、会话存储和消息队列,通过选择合适的数据结构、使用管道和事务、以及进行监控和调优,可以显著提升其性能。

安全地處理JSON中的函數和正則表達式在前端開發中,經常需要將JavaScript...
