binlog は、MySQL のすべての DML 操作を記録するバイナリ ログ ファイルです。 binlog ログを通じて、データ復旧、増分バックアップ、マスター間レプリケーション、マスター スレーブ レプリケーションなどを実行できます。開発者は binlog にあまり注意を払わないかもしれませんが、運用や保守、アーキテクチャ担当者にとっては非常に重要です。 MySQL 5.7 では、デフォルトでは binlog が有効になっていません。有効にする方法の詳細については、https://www.jb51.net/article/207953.htm を参照してください。 binlog が正常に有効化されると、my.inf 構成ファイルで binlog ファイルの場所を確認できます。 MySQL コマンドラインでも表示できます。コマンドラインビューコードは次のとおりです。 '%log_bin%' のような変数を表示します。 現在のMySQLのbinlogの状況も見てみましょう マスターステータスを表示します。 上の図からわかるように、現在 binlog ファイルは 1 つだけあり、ファイル名は mysql-bin.000001 です。再起動するたびに、binlog ファイルが自動的に生成されます。再起動後に同じコマンドを再度実行すると、内容は次のようになります。 binlog が保存されているディレクトリにもこのようなファイルが存在します。 もちろん、binlog ファイルを手動で更新することもできます。ログをフラッシュすると、新しい binlog ファイルも作成されます。実際、サーバーが再起動されると、ログのフラッシュ操作も呼び出されます。 これらのファイルをすべて消去したい場合は、リセットマスターを使用して処理できます。 次に、単一のファイルの操作を見てみましょう。まず、ファイルの内容を確認します。 binlogディレクトリを探します。たとえば、mysql-bin.000001を確認します。 vi mysql-bin.000001 意味不明な文字が並んでいます。これは一連のバイナリ ファイルであることはわかっているので、バイナリ ファイルをテキストとして開くと何か問題が発生するはずです。では、このファイルの内容を表示するにはどうすればよいでしょうか。 MySQLは、 mysqlbinlogと呼ばれるbinlogログを表示するためのツールを提供しています。 mysqlbinlog myql-bin.000001 このファイルはかなり長いです。一度で読み終えられない場合はどうすればいいでしょうか? Linux パイプを使用することができます。ここでは詳しく説明しません。Linux に関する知識は自分で調べることができます。 上記のスクリーンショットには位置フィールドがあることに注意してください。このフィールドはポインターに似ています。このフィールドの現在の値は 154 で、これはバイナリログの現在の位置を示しています。 DML 操作を実行するたびに、位置が変更されます。たとえば、データテストを作成しましょう 作成する前に、便宜上、binlog ログをクリアし、リセット マスターを使用できます。実稼働環境では、この操作は非常に危険なので、フラッシュ ログを使用して処理し、新しい binlog ファイルを生成することができます。使用する方法に関係なく、テスト環境では新しい binlog ファイルのみが必要です。新しいbinlogファイルを生成した後、show master statusでステータスを確認できます。 dmlステートメントを実行してみましょう。たとえば、テストデータベースを作成します。 データベーステストを作成します。 次に、作成後のステータスを確認してみましょう。以下に示すように、位置が 154 から 313 に変更されていることがわかります。これは、操作が 154 と 313 の間で行われていることを意味します。次に、binlog の内容を確認してみましょう。 次のように、154 から 313 の間の binlog の内容を傍受します。 # 154 で #170708 9:24:02 サーバー ID 12345 end_log_pos 219 CRC32 0x30763ffe Anonymous_GTID last_committed=0 シーケンス番号=1 @@SESSION.GTID_NEXT を 'ANONYMOUS'/*!*/ に設定します。 # 219 で #170708 9:24:02 サーバー ID 12345 end_log_pos 313 CRC32 0x4d0140b3 クエリ thread_id=5 exec_time=0 error_code=0 タイムスタンプを 1499477042/*!*/ に設定します。 @@session.pseudo_thread_id=5/*!*/ を設定します。 @@session.foreign_key_checks=1、@@session.sql_auto_is_null=0、@@session.unique_checks=1、@@session.autocommit=1/*!*/ を設定します。 @@session.sql_mode を 1436549152/*!*/ に設定します。 @@session.auto_increment_increment=1、@@session.auto_increment_offset=1/*!*/ を設定します。 /*!\C utf8 *//*!*/; @@session.character_set_client=33、@@session.collation_connection=33、@@session.collation_server=8/*!*/ を設定します。 @@session.lc_time_names=0/*!*/ を設定します。 @@session.collation_database=DEFAULT/*!*/ を設定します。 データベーステストの作成 //*!*/; SET @@SESSION.GTID_NEXT= 'AUTOMATIC' /* mysqlbinlog によって追加されました */ /*!*/; 区切り文字 ; # ログファイルの終了 /*!50003 COMPLETION_TYPE を @OLD_COMPLETION_TYPE に設定*/; /*!50530 @@SESSION.PSEUDO_SLAVE_MODE を 0 に設定します*/; MySQL は多くの暗黙的な操作を実行していることがわかります。注意深い友人は次の文に気付くでしょう: create database test; バイナリログを簡単にまとめてみましょう: 1. サービスが開始すると、binlog ファイルが新しいファイルを作成します。 2. フラッシュログを使用して手動でログを更新し、新しいバイナリログファイルを生成することができます。 3. show master statusでbinlogのステータスを確認できます。 4. マスターをリセットすることで、binlogログファイルをクリアできます。 5. binlogログの内容はmysqlbinlogツールで表示できます。 6. dmlを実行すると、mysqlは自動的にbinlogを記録します。 MySQL binlog ログの詳細な使用方法に関するこの記事はこれで終わりです。MySQL binlog ログの使用に関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: ローカル Docker に Postgres 12 + pgadmin をインストールする方法 (Apple M1 をサポート)
>>: ウェブサイトのデザインでは色の階層感覚に注意を払う必要があります
yum か rpm か? yum によるインストール方法は非常に便利ですが、公式サイトから MySQ...
目次1. プロジェクトの構築2. Vue3 体験 + Vant 紹介2020年9月18日にvue.j...
何?何のスターコートですか?さて、もっとわかりやすくするために写真を見てみましょう。 よく見ると、パ...
1. Alibaba Cloudは、個人のニーズに応じて適切なクラウドサーバーを選択し、CPU、メ...
序文HTTP と HTTPS日常生活でよく使われる URL は、おおまかに次の 2 種類に分けられま...
この記事の例では、マウス切り替え画像を実現するためのjsの具体的なコードを参考までに共有しています。...
目次1. 使用2. メッセージポップアップウィンドウが繰り返し表示される問題を解決する1. 使用Vu...
目次1. テーブル名を変更する方法2. 注記要約: 1. テーブル名を変更する方法RENAME TA...
導入Alibaba Cloud のような OSS ストレージ サービスを使用している場合は、サービス...
1. HTML_falshアニメーションでのマルチメディアの応用(WebページへのFlashアニメー...
目次混合継承の影響: 1. 継承Vue.extend メソッドプロパティを拡張する2. ミックスイ...
ウェブサイトを見るというのは、実は美しい女性を評価するようなものです。見た目を見るとき、私たちは見た...
導入Docker コミュニティは、さまざまなユースケースを処理するのに役立つ多くのオープンソース ツ...
ログインページなどのホームページを作成する場合、大きな背景画像を配置する必要があり、さまざまな画面の...
Linux で Ctrl+c、Ctrl+d、Ctrl+z はどういう意味ですか? Ctrl+c と ...