MySQL 日志:undo log、redo log、binlog以及MVCC的介紹

一、MySQL 日志:undo log、redo log、binlog

undo log(回滾日志):是 Innodb 存儲引擎層生成的日志,實現了事務中的原子性,主要用于事務回滾和 MVCC(隔離性)。
redo log(重做日志):是 Innodb 存儲引擎層生成的日志,實現了事務中的持久性,主要用于掉電等故障恢復;
binlog (歸檔日志):是 Server 層生成的日志,主要用于數據備份和主從復制;

MVCC(多版本并發控制)詳解

MVCC是數據庫領域用于解決高并發場景下讀寫沖突的核心技術。其核心思想是:為數據的每一次修改生成一個 “版本”,讀操作只訪問符合條件的歷史版本,從而實現 “讀不加鎖、寫不阻塞讀”,大幅提升數據庫并發性能。

二、MVCC 的核心目標:解決并發難題

在數據庫并發場景中,傳統的 “鎖機制” 會導致?讀寫互斥(讀操作加共享鎖,寫操作加排他鎖,兩者沖突),引發性能瓶頸。MVCC 的出現就是為了在 “并發控制” 與 “性能” 之間找到平衡,具體目標包括:

  1. 避免讀寫阻塞:讀操作(SELECT)無需等待寫操作釋放鎖,寫操作(UPDATE/DELETE/INSERT)也無需阻塞讀操作。
  2. 支持事務隔離級別:實現 MySQL 中的?Repeatable Read(可重復讀)?和?Read Committed(讀已提交)?隔離級別(InnoDB 默認使用 Repeatable Read,通過 MVCC 避免幻讀)。
  3. 提高并發吞吐量:減少鎖競爭,讓多個事務可以同時讀寫數據庫,提升系統整體處理能力。

通俗理解一下:可以把 MVCC 理解成數據庫的 “時光機” 機制,專門解決多個人同時操作數據時的沖突問題。
打個比方:你在看一本電子書(讀數據),同時另一個人在修改這本書的內容(寫數據)。沒有 MVCC 的話,你可能會看到亂七八糟的半成品內容,或者對方修改時你得一直等著不能看。
但有了 MVCC 就不一樣了:
數據庫會給每條數據拍 “快照”,你看書時翻到的是某一時刻的完整版本(快照讀),不受別人修改的影響;
別人修改時,會新建一個新版本的數據,舊版本依然保留給正在讀的人用;
等你看完(事務結束),舊版本可能會被悄悄清理掉,不占額外空間。
這樣一來,“讀” 和 “寫” 互不干擾,不用排隊等待,數據庫并發處理能力就大大提高了。這就是 MVCC 的核心作用 —— 通過保留數據的多個版本,讓讀寫操作能同時進行。

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

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

相關文章

【面板數據】省及地級市農業新質生產力數據集(2002-2025年)

農業新質生產力是以科技創新為核心驅動力,以科技化、數字化、網絡化和智能化為主線,通過技術革命性突破、生產要素創新性配置、產業深度轉型升級,實現農業全要素生產率顯著躍升的先進生產力形態 本數據基于2002-2025年各省政府工作報告中關于…

20250917在榮品RD-RK3588-MID開發板的Android13系統下使用tinyplay播放wav格式的音頻

input keyevent 24 1|console:/sdcard # cat /proc/asound/cards console:/sdcard # ls -l /dev/snd/【需要打開Android13內置的音樂應用才會有聲音出來,原因未知!】 1|console:/sdcard # tinyplay /sdcard/Music/kiss8.wav -D 1 -d 020250917在榮品RD-R…

總共分為幾種IP

IP(Internet Protocol)地址根據不同的分類標準可分為多種類型,以下是常見的分類方式:按版本分類IPv4:32位地址,格式為四組十進制數字(如192.168.1.1),約43億個地址&#…

【Linux】常用命令(六)

【Linux】常用命令(六)1. yum命令1.1 基本語法1.2 常用命令2. 從服務器把數據cp到本地3. uname命令3.1 常用命令1. yum命令 全稱:Yellowdog Updater, Modified作用:是 RPM 包管理器的前端工具,用于基于 RPM 的 Linux …

go grpc開發使用

1、安裝proto 下載 Windows 版本 打開官方發布頁面 訪問 Protocol Buffers 的 GitHub Releases 頁面: 👉 https://github.com/protocolbuffers/protobuf/releases 解壓 ZIP 文件 將下載的 ZIP 文件解壓到一個你容易找到的目錄,例如&#xff1…

MyBatis分頁:PageHelper

MyBatis分頁:PageHelper 📖 前言:為什么需要分頁? 在處理大量數據時,一次性從數據庫查詢并返回所有結果是不可行的,這會帶來巨大的性能和內存開銷。分頁是解決這一問題的標準方案。而PageHelper是一個極其流…

Gin框架:構建高性能Go Web應用

Gin框架:構建高性能Go Web應用 Gin是Go語言中最受歡迎的Web框架之一,以其高性能、簡潔API和豐富的中間件支持而聞名。本文將帶你從零開始,逐步掌握Gin框架的核心概念和高級特性,并通過實際代碼示例演示如何構建高效的Web應用程序。…

IO進程——線程、IO模型

一、線程Thread1、引入1.1 概念相當于是一個輕量級的進程,為了提高系統的性能引入線程,在同一進程中可以創建多個線程,共享進程資源1.2 進程和線程比較相同點:都為操作系統提供了并發執行的能力不同點:調度和資源&…

人工智能概念:NLP任務的評估指標(BLEU、ROUGE、PPL、BERTScore、RAGAS)

文章目錄一、評估指標基礎1. 準確率(Accuracy)2. 精確率(Precision)3. 召回率(Recall)4. F1-Score5. 示例二、文本生成專用指標1. BLEU:機器翻譯與標準化文案的“質量標尺”1.1 計算流程&#x…

團隊對 DevOps 理解不統一會帶來哪些問題

團隊對DevOps理念與實踐的理解不統一、片面甚至扭曲,是導致眾多企業DevOps轉型失敗的根本原因,它將直接引發一系列深層次的、相互關聯的嚴重問題。核心體現在:轉型極易淪為“為了工具而工具”的盲目自動化,導致最核心的文化變革被…

企業級實戰:構建基于Qt、C++與YOLOv8的模塊化工業視覺檢測系統(基于QWidget)

目錄一、概述二、項目目標與技術架構2.1 核心目標2.2 技術選型2.3 軟件架構三、AI推理DLL的開發 (Visual Studio 2019)3.1 定義DLL接口 (DetectorAPI.h)3.2 實現核心功能 (DetectorAPI.cpp)四、Qt Widget GUI應用程序的開發4.1 項目配置 (.pro 文件)4.2 UI設計 (mainwindow.ui)…

SVN自動化部署工具 腳本

SVN自動化部署工具 功能概述 這是一個自動化部署SVN倉庫的bash腳本,主要功能包括: 自動安裝SVN服務(如未安裝) 創建SVN項目倉庫 配置多用戶權限 設置自動同步到網站目錄 提供初始檢出功能 下載地址 https://url07.ctfile…

Facebook主頁變現功能被封?跨境玩家該如何申訴和預防

不少跨境玩家在運營Facebook公共主頁時,最期待的就是通過變現工具獲得穩定收入。但現實中,經常會遇到一個扎心的問題:主頁好不容易做起來,卻突然收到提示——“你的變現功能已被停用”。這意味著收入中斷,甚至可能導致…

安裝es、kibana、logstash

下載 elk 下載地址 elasticsearch地址: https://www.elastic.co/cn/downloads/elasticsearch kibana地址: https://www.elastic.co/cn/downloads/kibana logstash地址: https://www.elastic.co/cn/downloads/logstash 解壓elk 創建es全家桶文件夾 cd /usr/local mkdir elk …

Django admin 后臺開發案例【字段/圖片】

這是一個簡單的django admin 管理后臺,這個應用案例主要是給運營人員進行填寫數據 主要功能包括: 上傳圖片功能【選擇上傳時可以預覽】【替換已有數據中的圖片時可以預覽新舊圖片】 每條數據都將會記錄操作歷史。記錄操作人是誰?修改內容是什么?并且定位責任到某一員。 …

【C++】const和static的用法

目錄🚀前言💻const:“只讀”的守護者💯修飾普通變量💯修飾指針💯修飾函數💯修飾類成員💯修飾對象🌟static:“靜態存儲”與“作用域控制”💯修飾全…

F019 vue+flask海外購商品推薦可視化分析系統一帶一路【三種推薦算法】

文章結尾部分有CSDN官方提供的學長 聯系方式名片 B站up: 麥麥大數據 關注B站,有好處! 編號: F019 關鍵詞:海外購 推薦系統 一帶一路 python 視頻 VueFlask 海外購電商大數據推薦系統源碼 (三種推薦算法 全新界面布局…

【大數據專欄】流式處理框架-Apache Fink

Apache Fink 1 前言 1.1 功能 1.2 用戶 國際 國內 1.3 特點 ◆ 結合Java、Scala兩種語言 ◆ 從基礎到實戰 ◆ 系統學習Flink的核心知識 ◆ 快速完成從入門到上手企業開發的能力提升 1.4 安排 ◆ 初識Flink ◆ 編程模型及核心概念 ◆ DataSet API編程 ◆ Data…

向內核社區提交補丁

一、背景 內核的版本一直以來一直在持續迭代,離不開眾多開發者的貢獻。有時候我們會根據項目要求基于現有的內核版本開發一些新的功能或者修復掉一些特定場下的問題,我們是可以將其提交給社區的。 一般提交社區有兩個基本原則,一是提交的補…

TENGJUN-USB TYPE-C 24PIN測插雙貼連接器(H14.3,4腳插板帶柱):USB4.0高速傳輸時代的精密連接方案解析

在高速數據傳輸與多設備互聯需求日益增長的當下,USB TYPE-C接口憑借其可逆插拔、高兼容性的優勢成為主流,而TENGJUN推出的USB TYPE-C 24PIN測插雙貼連接器(規格:H14.3,4腳插板帶柱) ,以對USB4.0…