コンセプト紹介: MySQL の redo ログにはトランザクションの動作が記録されることはご存じのとおりです。サーバーがクラッシュした場合、トランザクションをやり直すことでデータを復元できます。ただし、トランザクションをロールバックする必要がある場合があります。つまり、現在の状況になる前のトランザクションの状態を知る必要があります。この場合、undo ログが役立ちます。つまり、UNDO ログは、データを変更前の状態に復元するために使用されます。したがって、データベースを変更する場合、このプロセスで REDO ログと UNDO ログが生成されることを知っておく必要があります。 保管場所: また、REDO ログは一般に ib_log と呼ばれる REDO ログ ファイルに配置され、UNDO ログはデータベース内の「セグメント」に格納されることもわかっています。この概念については、8 月 21 日の記事で説明しました。忘れてしまった方は、戻って確認してください。UNDO ログ セグメントは、共有テーブルスペースにあります。 ロールバック操作: さて、私たちはすでにundoの概念を知っています。undoは実際には共有テーブルスペース内の領域です。その主な機能は、トランザクションを変更が行われる前の状態に復元することです。ただし、リカバリ状況は一般的に2種類に分かれており、1つは論理リカバリ、もう1つは物理リカバリです。ここで強調する必要があるのは、undoリカバリは論理リカバリであるということです。つまり、100万個のデータを挿入すると、InnoDBは新しいデータページを割り当ててこのデータを保存し、トランザクションがロールバックされると、undoの機能はデータページをリサイクルするのではなく、これらの挿入操作を削除操作に変更してロールバックを実行します。このプロセス中、共有表領域のサイズは変更されません。さらに、UNDO ログは削除操作を挿入操作に変換し、更新操作を逆更新操作に変換します。 削除方法: もう一つの注意点は、トランザクション共有テーブルスペースに UNDO ログを書き込むプロセスでは、REDO ログも書き込む必要があることです。トランザクションがコミットされると、トランザクションの永続性が有効になり、UNDO ログは不要になります。ただし、InnoDB は UNDO ログを直接削除するのではなく、UNDO ログのリンク リストに配置します。いつ削除するかは、MySQL パージ スレッドによって異なります。これは、他のトランザクションが UNDO ログを使用してこのレコードの以前のバージョンを取得する必要がないようにするために行われます。 スペース割り当て: 実際の運用では、データベース インスタンスが多数のトランザクションを実行する場合があります。各トランザクションの undo を保存するために別のログ データ ページを割り当てると、ストレージ領域が無駄になります。簡単な計算をしてみましょう。アプリケーションの TPS が 1000 であると仮定すると、各トランザクションに undo ページが割り当てられます。データ ページのサイズは 16kb で、1 分間に 60*1000 のデータ ページが生成されます。すると、1 分間に必要なスペースは約 960M のディスク領域となり、明らかに無理があります。そのため、innodb では undo ページを再利用できます。具体的な方法は、トランザクションがコミットされたときに、undo ページをリンク リストに入れ、undo ページの使用済み領域が 75% 未満かどうかを判断します。そうであれば、undo ページを再利用でき、後続の undo ログを現在の undo ログの後ろに追加できます。もちろん、show engine innodb status を使用してリンク リスト内の undo ログの数を表示することもできますが、ここでは説明しません。 上記はMySQLのundoログの詳細な内容です。MySQLのundoログの詳細については、123WORDPRESS.COMの他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
<<: アイデアをDockerに接続してワンクリックでデプロイする方法
>>: WeChatアプレット開発で遭遇したことのない落とし穴のまとめ
目次vue - スワイパープラグインを使用してカルーセルを実装するカルーセルのバグを解決するには、w...
XHTML CSS を使って Web ページをデザインし始めた頃は、タグの使用経験も少なく、あまり気...
目次序文導入1. 作用機序2. 自然から3. 時計と計算の比較4. メソッドはデータロジックの関係を...
1. オーバーフローOverflow はオーバーフロー(コンテナ)です。コンテンツがコンテナを越える...
0x00 はじめにWordPress は、世界で最も人気のある CMS システムです。PHP と M...
目次チュートリアルシリーズ1. ユーザー管理1. ユーザーアカウント2. アカウントの追加と削除3....
1. 準備LinuxシステムにTomcatをインストールし、デフォルトのポート8080を使用してTo...
SSH は Secure Shell の略で、安全な伝送プロトコルです。Ubuntu クライアントは...
場合によっては、データ内のデータを再利用する必要がありますが、データ内のデータはさまざまなフォーム、...
数日前に CentOS8 がリリースされました。8 の最初のバージョンですが、今日は VM12 に ...
MySQL が複数のテーブルを結合するときに、次のエラーが報告されます: [Err]1267 – 操...
Web ページ エンコーディングは英語では web page encoding と翻訳され、Web ...
nginx をインストールApple Mac ではインストールに brew を使用します。brew ...
目次スロークエリの基礎: データ取得の最適化データベースから不要なデータが要求されていないか確認する...
導入された HTML タグは、必ずしも XHTML 仕様に完全に準拠しているわけではありません。実際...