MySQLにおけるMTRの概念

MySQLにおけるMTRの概念

MTR は Mini-Transaction の略です。名前が示すように、これは「最小のトランザクション」と理解できます。MySQL では、基礎となるページへのアトミック アクセスのプロセスは Mini-Transaction と呼ばれます。ここでのアトミック操作とは、すべてが成功するかすべてが失敗するかのいずれかであり、中間状態がないことを意味します。

MTR は主に、UNDO ログと REDO ログを書き込むシナリオで使用されます。たとえば、B+ ツリー インデックスにレコードを挿入する場合、挿入は成功するか失敗するかのいずれかになります。このプロセスは MTR プロセスと呼ばれます。このプロセス中に、一連の redo ログが生成されます。このログ セットは、MySQL クラッシュ リカバリを実行するときに分割できない全体です。

3 つのステートメントを含むトランザクションがある場合、MTR の概念図は次のようになります。

ミニトランザクションは、一般的に次の 3 つの原則に従います。

  • 1. 修正ルール
  • 2. ウォルマート
  • 3. コミット時に強制ログ

ここでは、次の 3 つの原則について説明します。

1. 修正ルール

最初のルールを説明する前に、MySQL のラッチの概念を理解する必要があります。MySQL では、ラッチは軽量ロックです。ロックとは異なり、非常に短い時間ロックします。InnoDB では、ラッチはミューテックス (mutex) と rwlock (読み取り/書き込みロック) に分けられます。その目的は、重要なリソースを操作する同時スレッドの正確性を確保することです。

ラッチの概念を理解したので、次は固定ルールを見てみましょう。

データ ページを変更するには、このデータ ページの x ラッチを取得する必要があります。

ページにアクセスするには、S ラッチまたは X ラッチを取得する必要があります。

ページを保持しているラッチは、ページの変更またはアクセスの操作が完了するまで解放されません。

2. ウォルマート

WAL テクノロジについては、皆さんもよくご存知だと思います。これは、Innodb ストレージ エンジンがクラッシュ リカバリをサポートする根本的な理由です。つまり、データ ページを永続化する前に、まずメモリ内の対応するログ ページを永続化する必要があります。

3. コミット時に強制ログ

この原則は非常に重要です。つまり、トランザクションがコミットされると、クラッシュ回復ロジックを確実に実行するために、トランザクションによって生成されたすべての MTR ログが永続デバイスにフラッシュされる必要があります。

MTR を導入する理由は、MySQL 8.0 で導入される REDO ログ最適化に備えるためです。MySQL 5.7 では、MTR によってトランザクション内の操作のアトミック性が保証されます。ユーザーが操作を実行すると、データ ページが更新され、同時に redo ログが書き込まれます。mtr は redo ログのキャリアであり、各接続セッションのプライベート変数に存在します。 mtr が送信されると、ローカル redo ログがグローバル log_buffer にコピーされます。 redo ログの秩序性を保証するために、log_buffer へのアクセスにはロックが必要です。このロックは、前述の mutex です。このロックの保護下では、ローカル ログをグローバル バッファにコピーするだけでなく、バ​​ックグラウンド スレッドがフラッシュしてデータベース チェックポイントが前進し続けるのを支援するために、データ ページを flush_list に追加する必要があります。したがって、このロックは、MySQL の古いバージョンでは非常に競争力があります。 MySQL 8.0 ではこの問題が最適化されており、次の記事で詳しく分析します。

上記はMySQLにおけるMTRの概念の詳細な内容です。MySQL MTRの詳細については、123WORDPRESS.COMの他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • MySQL インストール図 MySQL グラフィック インストール チュートリアル (詳細な手順)
  • MySQL ユーザーの作成と認証方法
  • MySQL のヒント: PID ファイルを更新せずにサーバーが終了する問題の解決方法
  • MySQL の日付データ型と時刻型の使用法の概要
  • MySQL - ルートパスワードを変更する 4 つの方法 (Windows を例に)
  • MySQL における TIMESTAMP の使用法の詳細な説明
  • MySQL での一時テーブルの使用例
  • Python による MySQL データの総当たり攻撃の例
  • MySQL SELECT文の実行方法
  • 2 つの MySQL ユーザー削除ステートメント (delete user と drop user) の違い
  • MySQL 並列レプリケーションの簡単な分析

<<:  Vue+el-tableはセルの結合を実現します

>>:  Dockerを使用してMySQL 8.0をデプロイする方法の例

推薦する

LinuxシステムでのSystemC環境設定方法

以下はcentos7での設定方法ですsystemc ソース パッケージをダウンロード: System...

JavaScript の 3 つの BOM オブジェクト

目次1. 場所オブジェクト1. URL 2. 場所オブジェクトのプロパティ3. ロケーションオブジェ...

CSS ボックスの折りたたみに対する 5 つの解決策

まず、ボックスコラプスとは何でしょうか?親ボックスの内側にあるべき要素が外側にあります。第二に、箱は...

(MariaDB) MySQL のデータ型とストレージメカニズムの包括的な説明

1.1 データ型の概要データ型は、各フィールドに保存できるデータの種類、保存できるデータの量、保存で...

MySQL 8.0 をインストールした後、初めてログインするときにパスワードを変更する問題を解決する

MySQL 8.0.16で初回ログイン時のパスワードを変更する方法を紹介します。 MySQLデータベ...

単一の Nginx IP アドレスに複数の SSL 証明書を設定する例

デフォルトでは、Nginx は IP アドレスごとに 1 つの SSL 証明書のみをサポートします。...

npm 淘宝ミラー変更説明

1. トップレベルの使用法1. cnpmをインストールする npm i -g cnpm --regi...

Vueは動的コンポーネントを使用してTAB切り替え効果を実現します

目次問題の説明Vueの動的コンポーネントとはアプリケーションシナリオの説明実装手順ステップ 1 (新...

HTML レイヤード ボックス シャドウ効果のサンプル コード

まず、画像を見てみましょう。今日はこのエフェクトを作成します。 実は、何でもないんです。Web ペー...

Vue プロジェクトに Electron を追加するための詳細なコード

1. package.jsonに追加する "メイン": "electr...

クラウドネイティブテクノロジー Kubernetes (K8S) の紹介

目次01 Kubernetes とは何ですか? 02 KubernetesとCompost+Swar...

この記事ではCSSボーダーの使い方を説明します

境界線のスタイルborder-style プロパティは、表示する境界線の種類を指定します。 bord...

Reactは、読み込み、読み込み完了、読み込み失敗の3つの段階の原則分析を実装します。

最近ブログに書いたのですが、プロジェクトリストの中に写真がたくさんあり、最初は読み込みが遅いので、ス...

docker ログが取得できない問題の解決方法

毎日サービスをチェックしているときに、portainer からコンテナ ログを確認しようとしたところ...

VMware Workstation Pro が Win10 アップデートにより開けなくなる問題の解決方法

今夜の夕食後にノートパソコンの電源を入れたところ、問題が発生しました。通常、コンピューターがスリープ...