mysql5.7でbinlogを使用してデータを復元する方法

mysql5.7でbinlogを使用してデータを復元する方法

ステップ1: MySQLでbinlogが有効になっていることを確認する

'%log_bin%' のような変数を表示します。
log_bin はオンの場合有効になります。

ここに画像の説明を挿入

ステップ2: バイナリログファイルディレクトリに入り、バイナリログファイルを見つける

ここに画像の説明を挿入

mysql> show binary logs; # バイナリログファイルリストを取得しますmysql> show master status; # 現在書き込まれているバイナリログファイルを表示しますmysql> reset master; バイナリログをリセットします

ここに画像の説明を挿入

ステップ3: mysqlbinlogツールコマンドを使用して、データベースの追加、削除、変更、およびクエリレコードを表示します(有効にするにはmysqlbinlogディレクトリに切り替える必要があります)。または、binlogを直接指定します。

例 1 : 2021-3-12 14:00:00 から 2021-3-12 14:03:00 までの操作ログを照会します。データベースは g_xinxiangshop です。次のコマンドを入力して、データを予備の txt ファイルに書き込みます。

/usr/local/mysql/bin/mysqlbinlog --no-defaults --database=g_xinxiangshop --start-datetime="2021-3-12 14:00:00" --stop-datetime="2021-3-12 14:03:00" /usr/local/mysql/data/mysql-bin.000001 > /tmp/binlog.txt

例 2 : 2021-3-12 14:00:00 から 2021-3-12 14:03:00 までのデータベース g_xinxiangshop の操作ログを照会し、g_user テーブルのデータのみを含む操作レコードをフィルター処理します。次のコマンドを入力して、データを予備の txt ファイルに書き込みます。

/usr/local/mysql/bin/mysqlbinlog --no-defaults --database=g_xinxiangshop --start-datetime="2021-3-12 14:00:00" --stop-datetime="2021-3-12 14:03:00" /usr/local/mysql/data/mysql-bin.000001 | grep g_user > /tmp/binlog.txt

例3 :2021-3-15 15:25:00から2021-3-15 15:35:00までのデータベースg_shoptestの操作ログを照会し、画面に出力します。
/usr/local/mysql/bin/mysqlbinlog --no-defaults --database=g_shoptest --start-datetime="2021-3-15 15:25:00" --stop-datetime="2021-3-15 15:35:00" /data/mysql/mysql-bin.000001 |もっと見る

ここに画像の説明を挿入

画像は例 1 と例 2 と同じです。切り捨て操作と記録ポイントを確認した後、回復操作を実行できます。

ステップ4: bin_logを使用してデータを回復するテスト

mysqlにログイン
テスト

1.マスターをリセットし、binlogをリセットしてログを再生成する

ここに画像の説明を挿入

2.データを挿入し、その後誤って削除してテーブルをテストします。

ここに画像の説明を挿入

ここに画像の説明を挿入

3. bin-log コマンドを表示します: 'mysql-bin.000001' の binlog イベントを表示します。

ここに画像の説明を挿入

上の図に示すように、削除ポイントは928〜1294の間にあり、以前に追加されたデータは154〜520の間にあることがわかります。

ここに画像の説明を挿入

/usr/local/mysql/bin/mysqlbinlog /usr/local/mysql/data/mysql-bin.000001 --開始位置 154 --停止位置 520 | mysql -uroot -p g_shoptest

実行が完了したら、データを削除して復元したかどうかを確認します。

ここに画像の説明を挿入

binlog コマンド

1. 最も一般的に使用される方法は、指定されたデータ終了時にデータを復元することです。これは、データベースに直接復元できます。

mysqlbinlog --start-date="2021-3-12 14:00:00" --stop-date="2021-3-12 14:03:00" mysql_bin.000001 |mysql -uroot -p123456

2. 開始位置と終了位置を指定します。上記で生成されたバイナリ ログから、ログの開始位置と終了位置を知ることができます。リカバリ プロセス中に、位置 A から位置 B までのログを指定できます。指定するには、次の 2 つのパラメータが必要です。

  • --start-positon="50" // 50番地から開始することを指定します
  • --stop-position="100"// 位置 100 で終了するように指定します

/usr/local/mysql/bin/mysqlbinlog /usr/local/mysql/data/mysql-bin.000001 --開始位置 7903538 --停止位置 7904498|mysql -uroot -p123456

**一般的なエラーエラー: Log_event::read_log_event() のエラー: 'バイナリ ログに無効なイベントが見つかりました'、data_len: 31、event_type: 35

*この問題はmysqlbinlogのバージョンによって発生します

現在のOSで使用されているmysqlbinlogを表示する

シェル> mysqlbinlog
/usr/bin/mysqlbinlog

mysql で現在使用されている mysqlbinlog を表示します。

±--------------±------------------+
| 変数名 | 値 |
±--------------±------------------+
| ベースディレクトリ | /usr/local/mysql/ |
±--------------±------------------+

mysql> 'basedir' のような変数を表示します。

2つのバージョンを比較する

シェル> /usr/bin/mysqlbinlog --version
シェル> /usr/local/mysql/bin/mysqlbinlog --version

この問題を解決するには、mysqlbinlogパスを指定するだけです

/usr/local/mysql/bin/mysqlbinlog --no-defaults --database=g_xinxiangshop --start-datetime="2021-3-12 14:00:00" --stop-datetime="2021-3-12 14:03:00" /usr/local/mysql/data/mysql-bin.000001 > /tmp/binlog.txt

MySQL 5.7 で binlog を使用してデータを回復する方法に関するこの記事はこれで終わりです。MySQL binlog 回復の詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL データベースのリカバリ (mysqlbinlog コマンドを使用)
  • MySQL の Binlog 関連コマンドとリカバリテクニック
  • MySQL バイナリログデータ復旧: 誤ってデータベースを削除した場合の詳細な説明
  • MySQL でデータ復旧に binlog を使用する方法
  • MySQLデータベースのログファイル(binlog)を自動的に復元する方法を説明します
  • Linux 上の binlog ファイルを使用して MySQL データベースを復元する詳細な手順
  • MySQL の binlog ログと、binlog ログを使用してデータを回復する方法を説明します。
  • MySQLはmysqldump+binlogを使用して、削除されたデータベースの原理分析を完全に復元します。
  • MySQLはデータ復旧を実装するためにbinlogログを使用する
  • MySQL binlog を使用して誤って削除されたデータベースを復元する方法

<<:  Facebook によるインターネット サービスのほぼ完璧な再設計

>>:  VUEのデータプロキシとイベントの詳細な説明

推薦する

el-table ヘッダーでテキストを折り返す 3 つの方法の詳細な説明

目次問題の説明レンダリング3種類のコード要約する問題の説明通常、表のヘッダーは折り返されませんが、ビ...

MySQL 8.0.21 無料インストール版 設定方法 グラフィックチュートリアル

MySQLをインストールする6つの手順(インストールパッケージのみがインストール場所を選択できます)...

Linux のハードリンクとソフトリンクの原理と使用法の分析

Linux システムには、ファイル共有を解決するために使用できるリンク ファイルと呼ばれる種類のファ...

MySQL 8.0.20 のインストールと設定方法のグラフィックチュートリアル

MySQLのダウンロードとインストール(バージョン8.0.20)のチュートリアルは参考までに、具体的...

正の整数かどうかを判断するMYSQLカスタム関数の例コード

関数を記述できます。主に正規表現を使用して判断を行います。入力文字が空の場合は、「-」を使用して置き...

中国語でのNginx設定パラメータの詳細な説明(負荷分散とリバースプロキシ)

PS: 最近、nginx を詳細に紹介している <<High-Performance ...

Vue でスロットを使用する方法についての簡単な説明

定義と使用方法:コンポーネントのテンプレートでスロットタグの定義を使用します。デフォルトの表示値は、...

nginx プロキシ サーバーで双方向証明書検証を構成する方法

証明書チェーンを生成するスクリプトを使用して、ルート証明書、中間証明書、および 3 つのクライアント...

Mysql 中国語ソートルールの説明

MySQL を使用する際、フィールドをソートしたりクエリしたりすることがよくあります。通常は、中国語...

HTTPS の原則の説明

HTTPS ウェブサイトの構築コストが下がるにつれて、ほとんどのウェブサイトが HTTPS プロトコ...

MySQLビューの原理と使用法の詳細な説明

この記事では、例を使用して MySQL ビューの原理と使用方法を説明します。ご参考までに、詳細は以下...

Linux のよく使うコマンドの使い方を詳しく解説(第 2 回)———— テキストエディタのコマンド vi/vim

vi/vim の紹介どちらもマルチモード エディターです。違いは、vim が vi のアップグレー...

Vue のフィルターウィジェットの詳細な使用方法

この記事では、参考までにVue More Filter Itemウィジェットの実装方法を例として紹介...

1時間で学ぶMySQLの基礎

目次MySQL を使い始めるMySQL 管理6. MySQL サーバーを起動および停止します。 7....

MySQL 5.6 での table_open_cache パラメータの最適化と適切な構成の詳細な説明

1. はじめにtable_cache は非常に重要な MySQL パフォーマンス パラメータであり、...