MySQL マスター スレーブ データベースが同期されない問題を解決する 2 つの方法

MySQL マスター スレーブ データベースが同期されない問題を解決する 2 つの方法

MySQL マスター スレーブ データベースが同期されない問題を解決する 2 つの方法

作業中に、Mysqlのマスターデータベースとスレーブデータベースが同期されていないことが判明しました。

1. 非同期の状況

マスターライブラリ:

mysql>プロセスリストを表示します。

プロセスがスリープしすぎていないか確認します。正常だとわかりました。

マスターステータスを表示します。

それは普通のことだ。

mysql> マスターステータスを表示します。
+-------------------+----------+--------------+-------------------------------+
| ファイル | 位置 | Binlog_Do_DB | Binlog_Ignore_DB |
+-------------------+----------+--------------+-------------------------------+
| mysqld-bin.000001 | 3260 | | mysql、テスト、情報スキーマ |
+-------------------+----------+--------------+-------------------------------+
セット内の 1 行 (0.00 秒)

次にスレーブをチェックします

mysql>スレーブステータスを表示\G                                                
 
スレーブIO実行中: はい
スレーブSQL実行中: いいえ

スレーブが同期していないことがわかります

2. 解決策

ここに2つの解決策があります

方法1: エラーを無視して同期を続行する

この方法は、マスター データベースとスレーブ データベースのデータがそれほど変わらない場合、またはデータを完全に統合できない場合、およびデータ要件が厳しくない場合に適しています。

解決する:

奴隷を停止します。
 
#ステップエラーをスキップしたことを示します。後ろの数字は変数です。set global sql_slave_skip_counter = 1;
スレーブを起動します。

次にmysql> show slave status\Gを使用して表示します

mysql>スレーブステータスを表示\G
スレーブIO実行中: はい
スレーブSQL実行中: はい

OK、マスターとスレーブの同期ステータスは正常になりました。 。 。

方法2: マスタースレーブを再度実行し、完全に同期する

この方法は、マスター データベースとスレーブ データベースのデータが大きく異なる場合や、データを完全に統合する必要がある場合に適しています。

解決手順は次のとおりです。

1.まずメインデータベースに入り、データが書き込まれないようにテーブルをロックします。

コマンドを使用します:

mysql> 読み取りロック付きのテーブルをフラッシュします。

注:これは読み取り専用としてロックされており、ステートメントでは大文字と小文字は区別されません。

2. データのバックアップを実行する

#データをmysql.bak.sqlファイルにバックアップします

mysqldump -uroot -p -hlocalhost > mysql.bak.sql


ここで注意すべき点が 1 つあります。データベースのバックアップは定期的に実行する必要があります。より便利で、データの安全性を確保できるシェル スクリプトまたは Python スクリプトを使用できます。

3. マスターステータスを確認する

mysql> マスターステータスを表示します。
+-------------------+----------+--------------+-------------------------------+
| ファイル | 位置 | Binlog_Do_DB | Binlog_Ignore_DB |
+-------------------+----------+--------------+-------------------------------+
| mysqld-bin.000001 | 3260 | | mysql、テスト、情報スキーマ |
+-------------------+----------+--------------+-------------------------------+
セット内の 1 行 (0.00 秒)

4. データ復旧のためにMySQLバックアップファイルをスレーブマシンに転送する

scp mysql.bak.sql ルート@192.168.128.101:/tmp/

5.スレーブ状態を停止する

mysql> スレーブを停止します。

6. 次に、データベースからmysqlコマンドを実行してデータのバックアップをインポートします。

mysql> ソース /tmp/mysql.bak.sql

7. スレーブ同期を設定する

スレーブ同期を設定するときは、マスター データベースの show master status 情報内の | File | Position 項目である同期ポイントに注意してください。

マスターを、master_host = '192.168.128.100'、master_user = 'rsync'、master_port=3306、master_password='', master_log_file = 'mysqld-bin.000001'、master_log_pos=3260 に変更します。

8.スレーブ同期を再開する

mysql> スレーブを起動します。

9. 同期ステータスを確認する

mysql>スレーブステータスを表示\G  

スレーブIO実行中: はい
スレーブSQL実行中: はい

10. メイン データベースに戻り、次のコマンドを実行してテーブルのロックを解除します。

テーブルのロックを解除します。

上記は、MySQL データベースのマスター スレーブ同期の問題を解決するための 2 つの方法の詳細です。MySQL のマスター スレーブ データベース同期の問題を解決する詳細については、123WORDPRESS.COM の他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • Mysql データベースのマスタースレーブ同期構成
  • この記事では、MySQLのマスタースレーブ同期の原理を説明します。
  • Docker環境でMySQLを実行し、Binlogを有効にしてマスタースレーブ同期を構成する方法
  • MySQL マスタースレーブ同期、トランザクションロールバックの実装原理
  • MySQLデータベースのマスタースレーブ同期の実際のプロセスの詳細な説明
  • MySQL マスタースレーブ同期における server-id の例の詳細な説明
  • MySQLデータベースのマスタースレーブ同期構成と読み取り書き込み分離
  • MySQL マスタースレーブ同期の原理と応用

<<:  埋め込みJavaScriptと外部リンクの基本的な応用方法

>>:  あなたを救うために、私のテーブルは何を使えばいいでしょうか (Haiyu Blog)

ブログ    

推薦する

WeChatアプレットはシンプルなチャットルームを実装します

この記事では、WeChatアプレットの具体的なコードを共有し、簡単なチャットルームを実装します。具体...

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

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

CSS ラベルモード表示プロパティの詳細な説明

コードは次のようになります。 <!DOCTYPE html> <html> ...

MySQLメモリストレージエンジンに関する知識

メモリストレージエンジンに関する知識ポイントメモリ ストレージ エンジンは日常業務ではほとんど使用さ...

iframe の src を about:blank に設定した後の詳細

iframe の src を 'about:blank' に設定した後、"...

CSS のグリッドプロパティの使用に関する詳細な説明

グリッドレイアウト親要素に追加された属性グリッドテンプレートの列/グリッドテンプレートの行要素の行ま...

Linux サーバーのクイックアンインストールとノード環境のインストール (簡単に始められます)

1.まずnpmをアンインストールする sudo npm アンインストール npm -g 2. ノー...

JSのバイナリファミリーについての簡単な説明

目次概要ブロブBlob の動作BLOB ダウンロード ファイルブロブ画像のローカル表示BLOB ファ...

Linux ファイルディレクトリ管理コマンドの概要

タッチコマンドこれには 2 つの機能があります。1 つは、既存のファイルの時間タグを現在のシステム時...

非常に詳細な基本的なJavaScript構文ルール

目次01 JavaScript(略称:js) js は 3 つの部分に分かれています。 JavaSc...

JSはリクエストディスパッチャーを実装する

目次抽象化と再利用シリアルセグメントシリアル、セグメントパラレル要約するはじめに: JS は当然並列...

three.js で 3D ダイナミック テキスト効果を実現する方法

序文みなさんこんにちは。CSS ウィザードの alphardex です。以前、海外のウェブサイトを閲...

UbuntuでOpenCVをコンパイルしてインストールする方法

opencv2 の簡単なインストール: conda インストール --channel https:/...

JSの基本概念の詳細な紹介

目次1. JSの特徴1.1 マルチパラダイム1.2 説明1.3 シングルスレッド1.4 ノンブロッキ...

IE8でラベルの背景画像が表示されない問題の解決方法

今日、ちょっとした問題に遭遇し、長い間苦労しました。そのことを皆さんにシェアしたいと思います。 a ...