ステップ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の操作ログを照会し、画面に出力します。 画像は例 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 つのパラメータが必要です。
/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 をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: Facebook によるインターネット サービスのほぼ完璧な再設計
目次1. ソフトウェアとシステムイメージ2. 仮想マシンを作成する3. CentOS8をインストール...
背景クラスメートと row_id の境界問題について話し合ったので、ここで詳しく説明します。 Inn...
この方法は2021年2月7日に編集されました。私が使用しているバージョンは8.0.23です。事件の原...
この記事では、ある大学の健康報告システムを例に、Web 側の自動化操作を完成させます。使用したテクノ...
この記事では、例を使用して、MySQL の水平テーブルと垂直テーブル間の変換操作を実装する方法を説明...
グラデーションの背景色を作成するときは、 linear-gradient() 関数を使用して線形グラ...
今日は、ネイティブ JS で実装された見栄えの良いカウンターを紹介します。効果は次のとおりです。 以...
毎回インストールチュートリアルを探すのは面倒なので、後で確認できるように手順をバックアップします。解...
いつも、気づかないうちに時間というのは驚くほど早く過ぎていきます。小暑が過ぎ、中暑に突入しました。太...
目次1. グループクエリの概略図2. groupbyキーワード構文の詳細な説明3. 簡単なグループク...
新しい質問急いで来て、急いで行ってください。 「垂直グリッドとプログレッシブ行間隔 (パート 1)」...
Vueは宮殿グリッド回転抽選(CrossFireのxx転生に似ている)を実装しています。参考までに、...
最初にコード、次にテキストコードをコピーコードは次のとおりです。 <!DOCTYPE html...
CentOS 6 以前のバージョンでは、MySQL サーバー/クライアント インストール パッケージ...
1. テーブル内のフィールドの大文字と小文字の区別を設定するgorm クエリを使用する場合、MySQ...