MySQL でのログインを取り消す

MySQL でのログインを取り消す

コンセプト紹介:

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の他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • MySQL シリーズ: redo ログ、undo ログ、binlog の詳細な説明
  • MySQLのREDOログ(リドゥログ)とロールバックログ(アンドゥログ)の詳しい説明
  • MySQLの7種類のログの概要
  • MySQLはデータ復旧を実装するためにbinlogログを使用する
  • MySQL のスローログ監視の誤報問題の分析と解決
  • MySQL スロークエリログの役割と公開
  • MySQL スロークエリログの有効化と設定
  • MySQLを監視するためのbinlogログ解析ツールの詳しい説明:Canal
  • MySQL 中断された接続警告ログの分析
  • MYSQL SERVER のログファイルを縮小する方法
  • MySQL Undo ログと Redo ログの概要

<<:  アイデアをDockerに接続してワンクリックでデプロイする方法

>>:  WeChatアプレット開発で遭遇したことのない落とし穴のまとめ

推薦する

CSSレコードテキストアイコン配置のいくつかのソリューション

開発中に画像とテキストが 1 行に表示されることはよくあります。2 つのインライン要素を揃えるのは通...

Vue の匿名スロットと名前付きスロットの詳細な説明

目次1. 匿名スロット2. 名前付きスロット要約するスロット (slot) は、Vue のコンテンツ...

Vue3+スクリプト設定+ts+Vite+Volarプロジェクト

目次Viteを使用してvue + tsプロジェクトを作成するVue 3の3つの構文オプションAPIコ...

VMWare仮想マシンのcentosの時間が現地時間と矛盾する問題を解決する

VM Ware 仮想マシン CentOS の時刻は、次の図に示すように、現地時間と一致しません。おそ...

td セルを結合した場合の td 幅の問題

以下の例では、名前が入っている td の幅が 60px のとき、2 行目の文字数が少ない場合は正常に...

CentOS 8 カスタム ディレクトリ インストール nginx (チュートリアルの詳細)

1. ツールとライブラリをインストールする# PCRE は、Perl 互換の正規表現ライブラリを含...

Node.jsはMySQLデータベースの実戦記録を追加、削除、変更、チェックします

目次プロジェクトでデータベースを操作する3つのステップデータベースを操作するための具体的な手順1: ...

MySQL サービスに iptables ファイアウォール ポリシーを追加するためのソリューション

MySQL データベースが Centos7 システムにインストールされており、オペレーティング シス...

MySQL のデータ型とスキーマの最適化の詳細な説明

現在、MySQL の最適化について学習しています。この記事では、データ型とスキーマの最適化について紹...

Reactを使用する際の7つの落とし穴のまとめ

目次1. コンポーネントの肥大化2. 状態を直接変更する3. プロパティは数値を渡す必要があるが文字...

React Fiber構造の作成手順

目次リアクトファイバーの作成1. 始める前に2. React.renderから始める3. 終了リアク...

設計仕様に準拠した設計は良い設計でしょうか?

これまでの数年間、私はいわゆる「設計仕様」についてかなりの数の執筆やコンサルティングを行ってきました...

MySQL 5.7.17 のインストールと設定方法のグラフィック チュートリアル (Ubuntu 16.04)

公式 MySQL Web サイトから Ubuntu Linux 用の最新バージョンの MySQL を...

MySQL のフィールドに一意のインデックスを追加および削除する方法

1. PRIMARY KEY(主キーインデックス)を追加するmysql>ALTER TABLE...

Linux (Centos7) での redis5 クラスターの構築と使用方法の詳細な説明

目次1. 簡単な説明2. クラスターを作成する手順2.1. ディレクトリを作成する2.2. ソースコ...