01 問題の説明実稼働環境では、MySQL のマスター スレーブ レプリケーションが切断される状況によく遭遇します。マスター スレーブ レプリケーションが切断された場合、通常、問題を解決する手順は次のとおりです。 1. データベースで show slave status を使用して、レプリケーション切断の直感的な理由を確認し、現在のレプリケーション場所を記録します。 2. エラーログをチェックして、レプリケーション切断の理由をより詳しく分析します。 3. マスターとスレーブのレプリケーション関係を修復する 4. レプリケーション関係を修復できない場合は、スレーブデータベースを再構築する必要があります。 02 ソリューションマスターとスレーブのレプリケーション関係が壊れる理由はさまざまです。アプリケーションが使用できず、すぐに復旧する必要があるため、原因を客観的に分析する時間がない場合があります。この場合、レプリケーションの中断の問題とサービスの可用性の間でトレードオフを行い、それに応じて対処する必要があります。 マスターとスレーブ間のレプリケーションの中断を解決する一般的な方法は次のとおりです。 1. 他のスレーブライブラリを見つけてすぐに置き換えるこの方法では、アプリケーションに少なくとも 1 つのマスターと 2 つのスレーブのアーキテクチャが必要です。スレーブ ライブラリの 1 つに問題が発生した場合、他のスレーブ ライブラリをすぐにオンラインにしてアプリケーション アクセスを復元し、障害が発生したスレーブ ライブラリの問題の具体的な原因を後で調査できます。 2. コピー失敗のエラーをスキップする場合によっては、マスターとスレーブ間のレプリケーションが切断される理由を特定できます。たとえば、マスターにスレーブよりも 1 つ多いデータベース db_1 がある場合、マスターで drop database db_1 を実行すると、スレーブのレプリケーションは確実に切断されます。この場合は、トランザクションをスキップすることで解決できます。 方法 1: (現在のトランザクションを直接スキップする)GTID モードでは、次のコマンドで解決できます。 mysql> スレーブを停止します。 mysql> SET GTID_NEXT='xxxxxx:yyy'; ----- スキップするgtidイベントを設定します mysql> BEGIN;COMMIT; mysql> GTID_NEXT='AUTOMATIC' を設定します。 mysql>スレーブを起動します。 非 GTID モードでは、次のコマンドで解決できます。 奴隷を停止します。 sql_slave_skip_counterを1に設定します。 スレーブを起動します。 方法2: (新しい場所を指定する)バイナリログ分析を通じて次のトランザクションの具体的な場所がわかっている場合は、次のトランザクションの具体的な場所を指定しても解決できます。 GTID モードの場合: mysql> スレーブを停止します。 mysql> マスターをリセットします。 mysql> SET @@GLOBAL.GTID_PURGED ='xxxxxxx:yyyyyy' ----- は、これらの gtid イベントが実行されたことを示します。mysql> START SLAVE; GTID_PURGED は GLOBAL でなければならないことに注意してください。上記のコマンドは、set global gtid_purged='xxx:yyy' と記述することもできます。 非GTIDモードの場合: 奴隷を停止します。 マスターをmaster_log_file='mysql-bin.001360'、master_log_pos=676383371に変更します。 スレーブを起動します。 方法3: pt-slave-restartツールトランザクションをスキップしても切断が続く場合 (たとえば、スレーブ データベースで 100 個のデータを削除したが、マスター データベースでこれらの 100 個のデータを更新する場合)、切断された位置を継続的にスキップできる pt-slave-restart ツールを使用できます。 使い方は次のとおりです: pt-slave-restart -h 10.xxx.xxx.xxx -P ポート -u ユーザ -p パスワード 並列レプリケーションを使用すると、pt-slave-restart がエラーを報告する場合があります。このとき、並列レプリケーションをシングルスレッド レプリケーションに変更してから、pt-slave-restart ツールを使用できます。次の記事を参照してください。 pt-slave-restart ツール 方法4: パラメータslave_exec_modeを設定するこのパラメータは、マスタースレーブレプリケーションプロセス中のスレーブライブラリ実行モードを変更できます。厳密モードに設定すると、エラーが報告されるとすべてのレプリケーションが停止します。べき等モードに設定すると、特定のエラー番号のエラーはスキップされます。コマンドは次のとおりです。 グローバルslave_exec_modeをidempotentに設定する 詳細については、前回の記事を参照してください。 MySQL レプリケーション問題の 3 つのパラメータの紹介 この記事には、レプリケーション エラーをスキップするための他の 2 つのパラメーター、slave_skip_errors と sql_slave_skip_counter があります。 3. バックアップを使用してスレーブライブラリを再構築するこの方法は多くのシナリオでは使用されません。通常、この方法は、スレーブ ライブラリが使用できないか、マスター ライブラリと同期できない場合にのみ検討されます。たとえば、マスター ライブラリでマスター リセット操作が実行され、すべてのバイナリ ログがクリアされます。この場合、スレーブ ライブラリは正しいバイナリ ログを取得して読み取ることができず、レプリケーションが切断されます。この場合、スレーブ ライブラリを再構築することが唯一の方法である可能性があります。 上記は、MySQL マスター スレーブ レプリケーション切断の一般的な修復方法の詳細です。MySQL マスター スレーブ レプリケーション切断の修復の詳細については、123WORDPRESS.COM の他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
<<: ユニアプリプロジェクトでのウォーターフォールレイアウトの実装
>>: JavaScriptの厳密モードが8進数をサポートしていない問題の説明
序文Linux では、コンパイルとリンクには Makefile を使用する必要がありますが、適切な ...
フォームのコードは図の通りです。スタイルシートがまだ追加されていないため、フォームが整列されておらず...
問題の背景業務システムのサーバ監視システムからディスク使用率が90%に達したという早期警告通知が来た...
目次1. 切り捨て操作1.1 MySQL truncate はどのような操作を実行しますか? 1.2...
時間に余裕を持って、過去を忘れましょう。前のセクションでは、[検索] フォームとクエリおよびリセット...
最近、自宅サーバーにクラウドディスクを導入する予定なので、一連の環境構築作業を始めました。MySQL...
最近、docker load -i コマンドを使用してイメージ パッケージを圧縮した後、イメージ名と...
最近、Rails 経由で「utf8」でエンコードされた UTF-8 文字列を MariaDB に保存...
目次ブール型数値型文字列型文字列と数値を連結する未定義およびnull配列型タプル型列挙型あらゆるタイ...
この記事では、MySQL マスター/スレーブ データベースの構築方法について説明します。ご参考までに...
目次1. はじめに2. MVCC (マルチバージョン同時実行制御メカニズム) 2.1 繰り返し読み取...
まずmysqlを削除します: sudo apt-get remove mysql-*残ったデータをク...
<br />テキストデザインでは、通常、テキストのレイアウト、つまりテキストをより美しく...
目次etcdの機能etcdが独自の高可用性クラスタを構築するには、主に3つの形式があります。今回構築...
目次アレイ重複排除1 2層forループ(バブルソートの2層ループ記述に類似) 2 ループとインデック...