Redis-典型應用-分布式鎖

目錄

1.什么是分布式鎖?

2.分布式鎖的實現

3.引入過期時間

4.引入校驗ID

5.引入lua腳本:

6.引入看門狗(watch dog)

7.引入redislock算法:


1.什么是分布式鎖?

?在 分布式系統中,會出現多個節點同時訪問同一個公共資源, 此時就需要通過鎖來作互斥控制,避免出現類似于多線程中的"線程安全"問題.

2.分布式鎖的實現

分布式鎖實現的本質是 通過一個鍵值對來標識鎖的狀態.在redis上寫入一個key-val.

mysql的事務也能起到避免線程安全問題實現查詢+修改操作,但是在實際使用的過程中,不一定是mysql, 也可能是其他存儲介質.

加鎖: 不能存在時就設置,存在就設置失敗,可以使用redis中的setnx 命令可以實現這個場景.

解鎖: 使用del命令實現.

3.引入過期時間

當對一個數據加鎖后,若還未執行解鎖的邏輯,程序突然崩潰了,就會導致加了鎖無法正常釋放.

可以通過設置一個過期時間機制,達到過期時間,自動刪除.達到鎖被自動釋放的效果.

通過 set ex nx命令來實現.

setnx ,expire這兩個命令也能實現設置過期時間的功能,但不能通過這個命令來實現.

因為redis的命令的原子性,隨能保證不允許被別的命令插隊,但不能保證一個事務中的所有命令是全部執行成功,若中間有命令執行失敗,就無法保證鎖的正確設置了.

通過set nx ex一條命令,一定能保證要么執行成功,要么全部執行失敗.

4.引入校驗ID

當一個服務器對redis設置了一個key-val.,進行了加鎖;

而另一個服務器對redis中的該值進行了誤刪除,這就出現了錯誤的邏輯.

為了解決這個問題,可以引入校驗id,讓key對應的val中存儲加鎖的服務器編號,當進行解鎖時, 只有該編號的服務器對其解鎖才能解鎖成功,其他服務器對其解鎖,都會解鎖失敗.

這樣就避免了誤刪除操作.

5.引入lua腳本:

在一個服務器內部,可能有多個線程.

當兩個線程前后對同一個redis進行解鎖時,由于解鎖的需要先判斷是否是該服務器上鎖的,然后進行解鎖,不是原子性的,可能引發兩次解鎖.

在執行解鎖操作時,服務器一的線程1先執行get命令,判斷是否是該線程加的鎖,在執行del命令之前, 然后又一個線程2,執行get,此時還未解鎖,線程2的get是成功的,

然后線程1執行了del操作,鎖釋放成功,

線程2再執行del操作,就會執行失敗.這就是鎖被重復.

但若在3,4步之間,又有一個服務器2的線程執行set nx ex上操作,此時線程b的del命令由于已經通過了判定, 就會將服務器2剛上的鎖給釋放了,就會出現錯誤.這是釋放鎖的命令不是原子性造成的.

可以通過lua腳本來解決解鎖時命令不是原子的的問題,

lua腳本是一個輕量級的編程語言,內嵌到redis中,使用lua編寫一些程序,然后將這個腳本上傳到redis服務器上,就可以讓客戶來控制redis執行上述lua腳本命令了.

redis執行lua腳本的過程是原子的,相當于一條命令在執行.

6.引入看門狗(watch dog)

設置過期時間,當過期時間到了,還需要繼續使用呢,又要怎樣將過期時間進行續約呢?

使用"動態續約"來實現.

初始情況下,設置一個過期時間,當過期時間馬上到了,還未有線程來釋放鎖,就會自動續約,再加上一段過期時間,時間又快到了,任務還沒執行完,就再續上一段時間.這樣既能保證當任務還沒執行完時,不會自動解鎖,又能保證當程序中途出現崩潰,鎖還未釋放時,就無法自動續約了,當到了過期時間,就自動解鎖了.

7.引入redislock算法:

這里有個問題,當用來加鎖的redis出現故障了,突然掛了,那所有的加鎖信息就沒了.

這就要用之前的知識了,使用主從復制,引入多個從節點,進行主從信息同步,即使主節點掛了,從節點也保存了加鎖的信息.

但這里又有一個問題,主從節點數據同步是存在一個延遲性的,萬一主節點剛收到一個加鎖信息,還沒來得及同步給從節點,主節點就掛了,那樣就出現數據丟失了.

為了解決這個問題,可以使用redislock 算法:使用集群的方法,引入多個redis主節點,每個主節點都創建多個從節點,當要寫入數據時,對每個主節點都執行相同的寫入命令,起到一個備份的作用.

?當執行成功的節點個數超過總主節點的一半時,才視為執行成功,即使有某個主節點掛了,還有別的主節點已經存儲了數據.這樣就能保證加鎖,解鎖的正確性了.

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/89452.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/89452.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/89452.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Dinky (Mac) 本地開發環境搭建指南

目錄 一、前置條件 二、代碼準備 三、前端環境搭建 1. 安裝Node環境 2. 安裝PNPM 3. 構建前端 四、后端環境搭建 1. 本地編譯依賴 2. 添加必要依賴 3. 啟動后端服務 五、訪問系統 附錄:官方參考 一、前置條件 確保已安裝以下軟件: 軟件要求…

Java Set 集合詳解:從基礎語法到實戰應用,徹底掌握去重與唯一性集合

作為一名 Java 開發工程師,你一定在實際開發中遇到過需要去重、唯一性校驗、快速查找等場景。這時候,Set 集合 就成為你不可或缺的工具。本文將帶你全面掌握:Set 接口的定義與核心方法常見實現類(如 HashSet、TreeSet、LinkedHash…

在分布式系統中,如何保證緩存與數據庫的數據一致性?

口訣: 讀多寫少用旁路,先更庫再刪緩存; 強一致選寫透,緩存代理更庫走; 性能優先用寫回,異步批量有風險; 高并發加雙刪,延遲兜底防舊殘; 強一致用鎖串,并發雖低…

【洛谷P1417】烹調方案 題解

題目大意 一共有 nnn 件食材,每件食材有三個屬性,aia_iai?,bib_ibi? 和 cic_ici?,如果在 ttt 時刻完成第 iii 樣食材則得到 ai?tbia_i-t\times b_iai??tbi? 的美味指數,用第 iii 件食材做飯要花去 cic_ici? 的…

vue svg實現一個環形進度條組件

svg實現一個環形進度條設計初衷:本來想直接使用element的進度條組件的,但是好多屬性都沒有辦法控制。 UI設計的圖如下,需要控制未完成和已完成的顏色,端點的形狀改為普通的butt 所以使用svg實現了一個環形進度條組件element組件設…

02 51單片機之LED閃爍

文章目錄1、單片機1-1、簡介1-2、應用場景2、51單片機2-1、背景2-2、主要品牌及其產品2-3、基本組成2-4、命名規則3、單片機內部結構3-1、單片機內部結構圖3-2、單片機內部結構3-3、單片機內部管腳圖3-4、單片機最小系統3-5、開發板介紹4、點亮LED4-1、新建工程4-1-1、創建工程…

Typecho博客集成算術驗證碼防御垃圾評論實戰指南

文章目錄 Typecho實現算術驗證碼防御機器人垃圾評論的完整方案 背景與問題分析 技術方案設計 系統架構 技術選型 核心實現步驟 1. 創建驗證碼生成函數 2. 修改評論表單模板 3. 添加AJAX刷新功能 4. 創建驗證碼刷新接口 5. 添加評論提交驗證 安全增強措施 1. 防止暴力破解 2. 增…

clonezilla 導出自動化恢復iso

clonezilla 下載及U盤工具下載 clonezilla rufus U盤寫入工具ventoy U盤工具downloaddownloaddownload clonezilla 備份,連貫上一篇文章參考 Choose Clonezilla live (VGA 800x600) Wait for it to complete Language selection Keyboard Settings Select Mode …

深度學習模型開發部署全流程:以YOLOv11目標檢測任務為例

深度學習模型開發部署全流程:以YOLOv11目標檢測任務為例 深度學習模型從開發到部署的完整流程包含需求分析、數據準備、模型訓練、模型優化、模型測試和部署運行六大核心環節。YOLOv11作為新一代目標檢測模型,不僅延續了YOLO系列的高效實時性能&#xff…

單片機(STM32-串口通信)

一、串口通信基礎概念串口通信(Serial Communication)是一種在計算機和外部設備之間進行數據傳輸的通信方式。它通過串行方式逐位傳輸數據,是最基本和常用的通信接口之一。主要特點1. 串行傳輸(1)數據按位順序傳輸,一次只能傳輸一…

Redis學習其三(訂閱發布,主從復制,哨兵模式)

文章目錄9.Redis訂閱與發布9.1發布訂閱命令9.2示例10.Redis主從復制10.1概念10.2環境配置10.3集群搭建(一主二從配置)10.4使用規則&原理11.哨兵模式11.1基本概念11.2工作原理11.3使用案例12.緩存穿透,雪崩(待拓展)12.1緩存穿透…

跨平臺 App 如何無痛遷移到鴻蒙系統?全流程實戰+Demo 教程

摘要 目前,隨著 HarmonyOS(鴻蒙系統)的快速發展,越來越多開發者和企業希望將已有的 Android、Flutter、React Native 等跨平臺應用遷移到鴻蒙生態中。鴻蒙不僅具備分布式能力、原生性能和統一的開發范式,還提供了豐富的…

智慧后廚檢測算法構建智能廚房防護網

智慧后廚檢測:構建安全潔凈廚房的智能解決方案背景:傳統后廚管理的痛點與智慧化需求餐飲行業后廚管理長期面臨操作規范難落實、安全隱患難察覺、衛生狀況難追溯等痛點。傳統人工巡檢效率低、覆蓋面有限,難以實現24小時無死角監管。例如&#…

LatentSync: 一鍵自動生成對嘴型的視頻

LatentSync是什么 字節跳動與北京交通大學聯合推出了全新的唇形同步框架 LatentSync,它基于音頻驅動的潛在擴散模型,跳過了傳統的3D建模或2D特征點提取,直接生成自然逼真的說話視頻。 LatentSync借助Stable Diffusion強大的圖像生成能力&am…

在斷網情況下,網線直接連接 Windows 筆記本和 Ubuntu 服務器進行數據傳輸

在斷網情況下,通過網線直接連接 Windows 筆記本 和 Ubuntu 服務器上的容器 進行數據傳輸,可以按照以下步驟操作:1. 物理連接 使用網線直連:用一根 普通網線(直通線) 連接 Windows 筆記本和 Ubuntu 服務器的…

機器學習17-Mamba

深度學習之 Mamba 學習筆記 一、Mamba 的背景與意義 在深度學習領域,序列建模是一項核心任務,像自然語言處理、語音識別和視頻分析等領域,都要求模型能有效捕捉長序列里的依賴關系。之前,Transformer 憑借強大的注意力機制成為序列…

Java實現word、pdf轉html保留格式

一、word轉html 依賴&#xff1a; <properties><poi.version>5.2.3</poi.version><xhtml.version>2.0.4</xhtml.version> </properties><!--word轉html--> <dependency><groupId>org.apache.poi</groupId><a…

基于51單片機和16X16點陣屏、矩陣按鍵的小游戲《俄羅斯方塊》

目錄系列文章目錄前言一、效果展示二、原理分析三、各模塊代碼1、16X16點陣屏&#xff08;MAX7219驅動&#xff09;2、矩陣按鍵3、定時器0四、主函數總結系列文章目錄 前言 《俄羅斯方塊》&#xff0c;一款經典的、懷舊的小游戲&#xff0c;單片機入門必寫程序。 有兩個版本&…

Stable Diffusion Windows本地部署超詳細教程(手動+自動+整合包三種方式)

Stable Diffusion Windows 本地部署超詳細教程 (手動 自動 整合包三種方式) 一、引言 我們可以通過官方網站 Stability AI&#xff0c;以及 Dream Studio、Replicate、Playground AI 、Baseten 等網站在線體驗 Stable Diffusion 的巨大威力。相比于集成在網絡平臺的 SD 或者…

sqli-labs靶場通關筆記:第29-31關 HTTP參數污染

第29關 HTTP參數污染本關設置了web應用防火墻&#xff08;WAF&#xff09;&#xff0c;利用白名單保護機制來檢測和攔截惡意請求。看本關源代碼。<?php //including the Mysql connect parameters. include("../sql-connections/sql-connect.php"); //disable er…