分布式系統的CAP理論、事務和鎖實現

分布式系統核心概念

1.?CAP理論

CAP理論指出,分布式系統最多同時滿足以下三項中的兩項:

  • 一致性(CC):所有節點訪問同一份最新數據。
  • 可用性(AA):每個請求都能在合理時間內獲得非錯誤響應。
  • 分區容錯性(PP):系統在網絡分區(節點間通信中斷)時仍能運行。

取舍場景

  • 當網絡分區(PP)發生時,需在CC與AA間選擇:
    • 選擇CC(如金融系統):拒絕寫入以保持一致性,犧牲可用性。
    • 選擇AA(如社交平臺):返回舊數據,犧牲一致性。

2.?分布式事務

解決跨服務或跨數據庫操作的數據一致性問題。

(1)2PC(兩階段提交)

  • 流程
    1. 準備階段:協調者詢問所有參與者“能否提交”。
    2. 提交階段:若所有參與者同意,協調者通知提交;否則回滾。
  • 問題:協調者單點故障可能導致參與者長期阻塞。

(2)TCC(Try-Confirm-Cancel)

  • 三階段
    1. Try:預留資源(如凍結庫存)。
    2. Confirm:提交(如扣減庫存)。
    3. Cancel:回滾(如解凍庫存)。
  • 缺點:需業務代碼實現補償邏輯,侵入性強。

(3)Seata的AT模式

  • 原理
    1. 自動生成反向SQL:記錄數據快照(UNDO_LOG),用于回滾。
    2. 全局鎖:防止其他事務修改同一數據。
  • 優點:業務侵入性低,無需手動編寫補償邏輯。

3.?分布式鎖

確保分布式環境下資源的互斥訪問。

(1)基于Redis的實現

  • 核心命令SETNX(或SET key value NX EX)設置鎖,Lua腳本保證原子性解鎖。
  • 示例
-- 加鎖(設置過期時間)
SET lock_key unique_value NX EX 30
-- 解鎖(Lua腳本驗證值后刪除)
if redis.call("get", KEYS[1]) == ARGV[1] thenreturn redis.call("del", KEYS[1])
elsereturn 0
end
  • 問題:鎖過期時間需合理,避免業務未完成鎖已釋放。

(2)基于ZooKeeper的實現

  • 臨時順序節點
    1. 客戶端創建臨時順序節點(如/lock/node_00000001)。
    2. 監聽前一個節點,若前序節點釋放,則獲取鎖。
  • Watcher機制:節點刪除時觸發通知,避免輪詢。
  • 優點:鎖自動釋放(會話斷開時節點刪除),無死鎖風險。

對比與總結

技術優點缺點
2PC強一致性協調者單點問題,性能低
TCC靈活性高需業務侵入,實現復雜
Seata AT自動化補償,低侵入依賴全局鎖,并發性能受限
Redis鎖高性能,易擴展鎖超時時間難設定
ZooKeeper鎖高可靠性,無死鎖性能低于Redis,依賴ZK集群

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

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

相關文章

鴻蒙UI開發

鴻蒙UI開發 本文旨在分享一些鴻蒙UI布局開發上的一些建議,特別是對屏幕寬高比發生變化時的應對思路和好的實踐。 折疊屏適配 一般情況(自適應布局/響應式布局) 1.自適應布局 1.1自適應拉伸 左右組件定寬 TypeScript //左右定寬 Row() { …

FreeRTOS 五種內存管理算法深度對比分析

FreeRTOS 提供了五種動態內存管理算法(heap_1 至 heap_5),針對不同應用場景在實時性、內存效率、碎片控制等方面進行了差異化設計。以下從實現原理、性能指標及適用場景進行全面對比: 一、Heap_1:靜態分配優先 ?核心…

基于EFISH-SBC-RK3576的無人機智能飛控與數據存儲方案

一、方案背景 民用無人機在電力巡檢、農業植保、應急救援等領域快速普及,但傳統方案面臨?多協議設備兼容性差?、?野外環境數據易丟失?、?復雜電磁干擾?三大痛點。 電魚智能推出?EFISH-SBC-RK3576?,可集成雙冗余總線接口與工業級加固存儲&#x…

怎樣進行服務器的日常安全監控和審計?

服務器的日常安全監控和審計是保障服務器安全運行的重要措施,以下是一些常見的方法和工具: 系統日志監控 啟用日志功能:確保服務器操作系統、應用程序和數據庫等都啟用了詳細的日志記錄功能。例如,Linux 系統中的 syslog&#x…

數據庫----單表、多表

數據庫 create database 數據庫名稱;---創建數據庫create database 數據庫名稱 default charsetutf8mb4;---創建數據庫,同時指定編碼show databases;---查看當前數據庫管理下存在多少數據庫show databases like "db_%";---查詢以db_開頭的數據庫select d…

DeepSeek 助力 Vue3 開發:打造絲滑的表格(Table)之添加行拖拽排序功能示例6,TableView16_06 分頁表格拖拽排序

前言:哈嘍,大家好,今天給大家分享一篇文章!并提供具體代碼幫助大家深入理解,徹底掌握!創作不易,如果能幫助到大家或者給大家一些靈感和啟發,歡迎收藏關注哦 💕 目錄 Deep…

遺傳算法優化支持向量機分類是一種將遺傳算法與支持向量機相結合的方法

遺傳算法優化支持向量機分類是一種將遺傳算法與支持向量機相結合的方法,旨在提高支持向量機的分類性能。以下是其相關內容的詳細介紹: 支持向量機(SVM) 原理:SVM是一種基于統計學習理論的機器學習方法,其…

Python中的Requests庫

什么是Python中的Requests模塊? requests模塊是Python中廣泛使用的庫,用于簡化HTTP請求的發送和響應處理。無論是調用API、下載文件、處理復雜會話管理,requests都能提供很好的解決方案。 一、基礎使用方法 1.GET請求 GET請求用于獲取服務…

復習MySQL20250327

第一章 基本操作 一、管理數據庫 難點:創建數據庫 輸入cmd的MySQL安裝路徑C:\Program Files\MySQL\MySQL Server 8.0\bin 1.查看所有數據庫 show databases; 2.創建數據庫 create database hsusers default charset utf8 collate utf8_general_ci;create data…

谷歌推出Gemini實時AI視頻功能,開啟智能交互新體驗

3月24日,谷歌發言人亞歷克斯約瑟夫向媒體證實,谷歌已開始向 Gemini Live 推出新的人工智能功能。這些功能使 Gemini 能夠“看到”用戶的屏幕內容,或通過智能手機攝像頭獲取畫面,并實時回答與之相關的問題。這一創新標志著人工智能…

Windows 新型零日漏洞:遠程攻擊可竊取 NTLM 憑證,非官方補丁已上線

近日,安全研究人員披露了一個新型 Windows 零日漏洞,影響從Windows 7和Server 2008 R2到最新Windows 11 v24H2及Server 2025的所有Windows操作系統版本。攻擊者只需誘使用戶在Windows資源管理器中查看惡意文件,即可利用該零日漏洞竊取NTLM&am…

一款超級好用且開源免費的數據可視化工具——Superset

認識Superset 數字經濟、數字化轉型、大數據等等依舊是如今火熱的領域,數據工作有一個重要的環節就是數據可視化。 看得見的數據才更有價值! 現如今依舊有多數企業號稱有多少多少數據,然而如果這些數據只是呆在冷冰冰的數據庫或文件內則毫無…

作業14 (2023-05-22_const修飾指針)

第1題/共5題【單選題】 C程序常見的錯誤分類不包含:( ) A.編譯錯誤 B.鏈接錯誤 C.棧溢出 D.運行時錯誤 回答正確 答案解析: 棧溢出是運行時錯誤的一種,因此C程序不會將棧溢出錯誤單獨列出來,棧溢出包含在運行時錯誤中。 因此:選擇C 第2題/共5題【單選題】 以下關于…

《Tr0ll2 靶機滲透實戰:弱口令+SUID+兩種緩沖區溢出+ 提權完整+fcrackzip暴力破解+shellshock漏洞+臟牛三種root提權復盤》

Tr0ll2 1、主機發現 arp-scan -l 2、端口掃描 nmap -sS -sV 192.168.66.181 nmap -sS -A -T4 -p- 192.168.66.181 nmap --scriptvuln 192.168.66.181PORT STATE SERVICE VERSION 21/tcp open ftp vsftpd 2.0.8 or later 22/tcp open ssh OpenSSH 5.9p1 Debian 5ubuntu1.4 (…

redis常用部署架構之redis分片集群。

redis 3.x版本后開始支持 作用: 1.提升數據讀寫速度 2..提升可用性 分片集群就是將業務服務器產生的數據儲存在不同的機器上。 redis分片集群的架構 如上圖所示,會將數據分散存儲到不同的服務器上,相比于之前來說,redis要處…

分布式數據庫介紹

分布式數據庫介紹 一、定義與核心概念 分布式數據庫是一種在物理上分散存儲、邏輯上統一管理的數據管理系統,其核心特征包括數據分布性、邏輯關聯性、場地透明性和可擴展性。根據最新定義,分布式數據庫需具備分布式事務處理能力、平滑擴展能力&#xf…

MybatisPlus(SpringBoot版)學習第五講:條件構造器和常用接口

目錄 1.wrapper介紹 2.QueryWrapper 2.1 例1:組轉查詢條件 Compare Nested Join Func 2.2 例2:組裝排序條件 2.3 例3:組裝刪除條件 2.4 例4:條件的優先級 2.5 例5:組裝select子句 2.6 例6:實現子查…

OkHttp 的證書設置

在 Android 開發中,通過 OkHttp 自定義 SSLSocketFactory 和 X509TrustManager 可以有效增強 HTTPS 通信的安全性,防止中間人攻擊(如抓包工具 Charles/Fiddler 的攔截)。以下是實現防抓包的關鍵技術方案: 一、Okhttp設…

計算機視覺算法實戰——手術導航:技術、應用與未來

?個人主頁歡迎您的訪問 ?期待您的三連 ? ?個人主頁歡迎您的訪問 ?期待您的三連 ? ?個人主頁歡迎您的訪問 ?期待您的三連? ??? ????????? ?? 1. 手術導航中的計算機視覺:領域介紹 計算機視覺在手術導航領域的應用代表了現代醫學與人工智…

【科研繪圖系列】R語言繪制PCA與變量的相關性散點圖(scatter plot)

禁止商業或二改轉載,僅供自學使用,侵權必究,如需截取部分內容請后臺聯系作者! 文章目錄 介紹加載R包數據下載導入數據畫圖輸出圖片系統信息介紹 【科研繪圖系列】R語言繪制PCA與變量的相關性散點圖(scatter plot) 加載R包 library(tidyverse) library(ggpubr)數據下載 …