MySQL マルチバージョン同時実行制御 MVCC の実装

MySQL マルチバージョン同時実行制御 MVCC の実装

トランザクション分離レベルの設定

グローバルトランザクション分離レベルを読み取りコミット済みに設定; //グローバルセッショントランザクション分離レベルを読み取りコミット済みに設定; //現在のセッション

トランザクションの送信方法を変更する(自動的に送信するかどうか、MySQL はデフォルトで自動的に送信します)

SET AUTOCOMMIT = 1; // 自動的にコミット、0 手動でコミット

異なるデータベース エンジンには異なる MVCC モードがあり、通常は楽観的同時実行制御と悲観的同時実行制御です。

インノDB

例:

InnoDB の MVCC は、レコードの各行の後に 2 つの隠し列を保存することによって実装されます。これら 2 つの列の 1 つは行の作成時刻を格納し、もう 1 つは行の有効期限 (または削除時刻) を格納します。もちろん、保存されるのは実際の時間値ではなく、システムのバージョン番号です。新しいトランザクションが開始されるたびに、システムのバージョン番号は自動的に増加します。トランザクション開始時のシステムバージョン番号は、照会されたバージョン番号と比較するためのトランザクションバージョン番号として使用されます。

選択

InnoDB は各行を次の 2 つの条件と照合します。

a. InnoDB は、現在のトランザクション バージョンよりも前のバージョンのデータ行のみを検索します (つまり、行のシステム バージョン番号がトランザクションのシステム バージョン番号以下です)。これにより、トランザクションによって読み取られる行は、トランザクションの開始前に存在していたか、トランザクション自体によって挿入または変更されたことが保証されます。

b. 削除された行のバージョンは未定義であるか、現在のトランザクション バージョン番号より大きいです。これにより、トランザクションによって読み取られた行が、トランザクションの開始前に削除されていないことが保証されます。

上記の 2 つの条件を満たすレコードのみがクエリ結果として返されます。

入れる

InnoDB は、新しく挿入された各行の行バージョン番号として現在のシステム バージョン番号を保存します。

消去

InnoDB は、削除された各行の行削除識別子として現在のシステム バージョン番号を保存します。

アップデート

InnoDB は、新しい行を挿入するときに現在のシステム バージョン番号を行バージョン番号として保存し、行削除マーカーとして元の行に現在のシステム バージョン番号を保存します。

知らせ:

MVCC は、REPEATABLE READ および READ COMMITED 分離レベルでのみ機能します。他の 2 つの分離レベルは MVCC と互換性がありません。READ UNCOMITTED では、現在のトランザクション バージョンに準拠するデータ行ではなく、常に最新のデータ行が読み取られるためです。 SERIALIZABLE はすべての読み取り行をロックします。

テーブルの状態を確認する

'task' のようなテーブル ステータスを表示します\G;

ダーティリード、非反復リード、ファントムリード

ダーティ リード: 現在のトランザクションは別のトランザクションのコミットされていない状態を読み取りますが、トランザクションは分離されていません。

反復不可能な読み取り: トランザクションの分離は達成されますが、同じデータが 2 回読み取られるとデータの不整合が見つかります。

ファントム リード: 同じデータ バッチを 2 回クエリすると、新しいデータが挿入されたことがわかります。これは主に、他のトランザクションがデータ セットの途中でデータを挿入したためです。 (ギャップロックを追加するとこの問題は解決します)

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • MySQLのMVCCマルチバージョン同時実行制御の実装
  • MySQL マルチバージョン同時実行制御メカニズム (MVCC) ソースコードの詳細な説明
  • MySQL マルチバージョン同時実行制御 MVCC の詳細な研究
  • MySQL マルチバージョン同時実行制御 MVCC の基本原理の分析
  • MySQL マルチバージョン同時実行制御 MVCC の実装
  • Mysql MVCC マルチバージョン同時実行制御の詳細

<<:  MySQLにおける分散ロックの考え方をDBの助けを借りて詳しく説明します

>>:  Nginx セッション共有問題の解決策の分析

推薦する

flexとは何か、flexレイアウト構文の詳細なチュートリアル

フレックスレイアウトFlex は Flexible Box の略で、「柔軟なレイアウト」を意味します...

VMware kali仮想マシン環境の設定方法

1|0 カーネルをコンパイルする(1)uname -rコマンドを実行してカーネルバージョンを表示しま...

Hadoop を使用せずに Linux 環境に Spark のスタンドアロン バージョンをインストールする方法

ビッグデータはますます注目を集めており、ビッグデータのいくつかの構成要素に精通していないと、自慢でき...

CSS はこのように使用できますか?気まぐれなグラデーションの芸術

前回の記事「1行のCSSコードの魅力」では、たった1行のCSSコードで生成できる美しい(奇妙な感じと...

Docker デプロイメント MySQL8 クラスター (マスター 1 台とスレーブ 2 台) の実装手順

目次1. CentOS 7.9 20にDockerをインストールする2. MySQL クラスターをデ...

Linux での Centos7 ファイアウォールの基本的な使用方法の詳細な説明

1. ファイアウォールの基本的な使い方起動する: systemctl は、firewalld を起動...

MySQL は ACID トランザクションをどのように実装しますか?

序文最近、面接中に、MySQL の InnoDB エンジンがどのようにトランザクションを実装している...

Linuxはデータディスクがアンインストールされ、新しいカスタムイメージを作成できることを確認します。

カスタムイメージに関するよくある質問データディスクを表示するにはどうすればいいですか? df コマン...

startup.bat をダブルクリックすると Tomcat がクラッシュする問題の解決方法の詳細な説明

Tomcat を学習したばかりのプログラマーにとって、これはよくある間違いです。 1. 環境変数の問...

JS ES6 変数分割代入の詳細な説明

目次1. 脱構築とは何か? 2. 配列の分割3. 配列モードと代入モードの統一4. デフォルト値の構...

Dockerfile における ENTRYPOINT と CMD の違い

Docker システムの学習チュートリアルでは、Dockerfile を使用して Docker イメ...

ショートビデオ(Douyin)の透かし除去ツールの実装コード

目次1. まず最初のリンクを取得する2. ブラウザでこのリンクを開いてください3. アドレスを開くと...

実行中の時計を実装するための純粋な CSS3 コード

操作効果コードの実装html <div id="ウォッチ"> <...

Flinkのフォールトトレラントメカニズムに関する簡単な説明:ジョブ実行とデーモン

目次1. ジョブ実行のフォールトトレランス1.1 タスクフェイルオーバー戦略1.2 ジョブ再開戦略2...

Linux の who コマンド例の紹介

誰についてシステムにログインしているユーザーを表示します。 who コマンドを実行すると、現在システ...