MySQL マスタースレーブレプリケーション切断の一般的な修復方法

MySQL マスタースレーブレプリケーション切断の一般的な修復方法

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

以下もご興味があるかもしれません:
  • MySQL5.7 並列レプリケーションの原理と実装
  • MySQL マスタースレーブレプリケーションと読み取り書き込み分離の詳細な説明
  • MySQL レプリケーション問題の 3 つのパラメータの分析
  • MySql マスタースレーブレプリケーションメカニズムの包括的な分析
  • MySQL シリーズ 13 MySQL レプリケーション

<<:  ユニアプリプロジェクトでのウォーターフォールレイアウトの実装

>>:  JavaScriptの厳密モードが8進数をサポートしていない問題の説明

推薦する

TypeScript で時間を費やした場所の概要

TS で時間を過ごした場所をいくつか記録します。 (まず、文句を言わせてください。stackover...

ファイルをアップロードするときに enctype フィールドを使用する理由は何ですか?

FORM 要素の enctype 属性は、フォーム データがサーバーに送信されるときに使用されるエン...

YUM を使用して Linux (CentOS 7) に MySQL 5.7.18 をインストールする方法の詳細なチュートリアル

このプロジェクトでは MySQL を使用する必要があります。これまで Windows では常に確実に...

vue3.0プロジェクトアーキテクチャを段階的に構築する方法を教えます

目次序文: 1. vue-cliでプロジェクトを作成する2. ルーターをインストールする3. ディレ...

MySQL 8.0.23 のレプリケーション アーキテクチャにおけるスレーブ ノードの自動フェイルオーバー

私はしばらく MGR と連絡を取り合ってきました。MySQL 8.0.23 の登場により、MySQL...

Linuxシステムにmsfをインストールするプロセスの詳細な説明

または、インストールプロセスを自分で書き留めてください。私のサーバーシステムはAliyun Linu...

Ubuntu は、Mysql+Keepalived の高可用性実装 (デュアルアクティブ ホットスタンバイ) を構築します。

Mysql5.5 デュアルマシン ホットスタンバイ実装 2つのMySQLをインストールするMySQ...

CSS 垂直センタリングの代替実装コードの詳細な説明(非従来型)

序文ご存知のとおり、「CSS で要素を垂直方向に中央揃えするにはどうすればよいか」という質問は、すで...

vue+django でファイルをダウンロードする例

目次1. 概要2. Django プロジェクト3. Vueプロジェクト1. 概要プロジェクトで、ダウ...

Vueでファジークエリを実装する方法の簡単な例

序文いわゆるファジークエリとは、ユーザーの完全な入力やすべての入力情報がなくてもクエリサービスを提供...

ハイパーリンクの幅と高さを直接設定できない問題の解決策

幅と高さを直接使用することはできません。 display:block; または display:in...

包括的なウェブサイト評価ソリューション

<br />「XXXのウェブサイトを見てみませんか?」といった質問をされることもあります...

ブラウザの自動更新を実装するReactサンプルコード

目次フロントエンドルーティングとは何ですか?フロントエンドルーティングを実装するにはどうすればいいで...

ベスト HTML/CSS デザインおよび開発フレームワーク 15 選を紹介します

プロフェッショナルな Web デザインは複雑で時間がかかります。 HTML と CSS フレームワー...

MySQLインストール後のデフォルトデータベースの役割の詳細な説明

MySQL を学習すると、インストール後にいくつかのデフォルトのデータベースが付属していることに気付...