検索
ホームページデータベースmysql チュートリアルMYSQL デュアルマスター完全データベース同期レプリケーションの詳細な例

環境:

2 つのサーバー A と B にはそれぞれ mysql-5.7.18 サーバーがインストールされ、互いのマスターとスレーブを同期するように構成されています。

LinuxのシステムバージョンはCentOS7です

AサーバーIP:192.168.1.7ホスト名:test1

BサーバーIP:192.168.1.8ホスト名:test2

(同一LAN内)

1.準備

1ホスト名変更 命コマンド: HostnameCTL SET-Hostname xxx

(ホスト名表示コマンド: hostname)

2. ファイアウォールをオフにします

1) ファイアウォールのステータスを表示します

2) ファイアウォールが実行中です、最初に終了しますファイアウォールサービスを停止します

コマンド: systemctl Mask firewalld

3) ファイアウォールをオフにします

コマンド: systemctl stop firewalld

4) ファイアウォールのステータスを確認します

コマンド: firewall-cmd --state

結果: 実行されていません

3. selinuxポリシーをオフにする

1) selinuxの実行状況を確認する

コマンド:getenforce

/etc/sysconfig/selinux edit SELINUX=disabled

3)closed状態に

2. マスターサーバー (master) スレーブサーバー (slave) を設定します

1. サーバー A の my.cnf ファイル vi /etc/my.cnf を開き、ファイル内の [mysqld] の下に次の内容を追加します

server-id=1 #他のサーバーと異なり、1~232の正の整数値である必要があります

log-bin=mysql-bin
   log-bin-index=mysql-bin

サーバーBのmy.cnfファイルの[mysqld]の下に上記の内容を追加します。 、server-id 値のみを変更します。

server-id=2    
   log-bin=mysql-bin
   log-bin-index=mysql-bin

2. サーバーAのmysqlインストールパス(rpmインストールパスは/var/lib/mysql)にデータベースの完全バックアップファイルall.sqlを作成します。

作成コマンド:

touch  /var/lib/mysql/all.sql

バックアップコマンド:

[root@test1 mysql]# mysqldump -uroot -p123 --all-databases > /var/lib/mysql/all.sql
リカバリのためにall.sqlファイルをサーバーBの特定のパス(例として/var/lib/mysqlパス)にコピーします。

復元コマンド:

[root@test2 /]# mysql -uroot -p123 < /var/lib/mysql/all.sql

3. サーバーAとサーバーBのmysqlに同期用のユーザーを作成します。

ユーザーの作成:

mysql> create user &#39;tongbu&#39;@&#39;%&#39; identified by &#39;tongbu&#39;;

認可:

mysql> grant all on *.* to &#39;tongbu&#39;@&#39;%&#39;;

ユーザーの削除:

mysql> drop user &#39;用户名&#39;@&#39;%&#39;;

AサーバーユーザーとBサーバーユーザーが作成されたら、ユーザーが相互にリモートからmysqlにログインできるかどうかをテストします。

[root@test1 /]# mysql -utongbu -ptongbu -h192.168.1.8
   [root@test2 /]# mysql -utongbu -ptongbu -h192.168.1.7

テストに問題がなければ、サーバー A と B で mysql サービスを再起動します: [root@test /]# service mysqld restart

4. A をマスター サーバー、B をスレーブ サーバーに設定します。

1)サーバーAのmysqlでバイナリログ名とオフセット値を表示します

コマンド:mysql> show master statusG

2)サーバーBで接続サーバーを設定します

mysql> stop slave;
    mysql> change master to
      -> master_host=&#39;192.168.1.7&#39;,
      -> master_user=&#39;tongbu&#39;,
      -> master_password=&#39;tongbu&#39;,
      -> master_log_file=&#39;mysql-bin.000024&#39;,
      -> master_log_pos=154;
    mysql> start slave;

mysql> スレーブステータスを表示G Enterこのコマンドは、以下に示すように、Slave_IO_Running と Slave_SQL_Running の値が Yes であるかどうかを確認します

5. B をマスター サーバー、A をスレーブ サーバーに設定します。

1)サーバーBのmysqlでバイナリログ名とオフセットを表示します

コマンド:mysql> show master statusG

2)サーバーAで接続サーバーを設定します。

mysql> stop slave;
    mysql> change master to
      -> master_host=&#39;192.168.1.8&#39;,
      -> master_user=&#39;tongbu&#39;,
      -> master_password=&#39;tongbu&#39;,
      -> master_log_file=&#39;mysql-bin.000027&#39;,
      -> master_log_pos=154;
    mysql> start slave;
    mysql> show slave status\G 查看Slave_IO_Running和Slave_SQL_Running的值是否为Yes

この時点で、2 つの mysql データベースはマスター/スレーブとして構成され、相互に同期されます。

エラーのトラブルシューティング:

1. Slave_IO_Running ステータス エラー

MySQL> show slide statusG; を確認すると、Slave_IO_Running ステータスが接続エラーになっています。設定を確認する必要があります。

1)ネットワークが利用できない

2) 間違ったパスワード、間違ったアカウント番号、間違ったアドレスなど、間違ったアカウント権限設定

3) 間違ったバイナリファイルの場所

2. 一次データと二次データの競合または相違によって引き起こされる異常

 主键冲突、表已存在等错误代码如1062,1032,1060等,可以在mysql配置文件指定略过此类异常并继续下条sql同步,这样可以避免很多主从同步的异常中断。打开/etc/ mysql下的my.cnf文件,在[mysqld]后添加如下代码:

slave-skip-errors = 1062,1032,1060

3. 跳过异常恢复同步

mysql >slave stop;
 mysql >SET GLOBAL sql_slave_skip_counter = 1;
 mysql >slave start;

以上がMYSQL デュアルマスター完全データベース同期レプリケーションの詳細な例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
MySQLは、他のリレーショナルデータベースと比較してトランザクションをどのように処理しますか?MySQLは、他のリレーショナルデータベースと比較してトランザクションをどのように処理しますか?Apr 29, 2025 am 12:37 AM

mysqlhandlestransactionsefectivectivelivationtivelivational supportingingacidpropertiessimilArtopostgreslesclandoracle.1)mysqluseSesrepeatable-readededededededededededefaultisolation level

MySQLはPostgreSQLとどのように違いますか?MySQLはPostgreSQLとどのように違いますか?Apr 29, 2025 am 12:23 AM

mysqlisbetterforspeedandsimplicity、適切なforwebapplications; postgresqlexcelsincomplexdatascenararios withobustfeatures.mysqlisidealforquickprojectsandread-havytasks、whilepostgressqlessqlispreredforforivationsRedictrictiontrictdateinitegriTinitegriTiontegriTioniitaintegrategrisioniationegrisioniaty

MySQLはデータレプリケーションをどのように処理しますか?MySQLはデータレプリケーションをどのように処理しますか?Apr 28, 2025 am 12:25 AM

MySQLは、非同期、半同期、およびグループ複製の3つのモードを介してデータの複製を処理します。 1)非同期の複製パフォーマンスは高くなりますが、データが失われる可能性があります。 2)半同期複製により、データセキュリティが向上しますが、遅延が増加します。 3)グループレプリケーションは、高可用性要件に適したマルチマスターレプリケーションとフェールオーバーをサポートします。

説明ステートメントを使用してクエリパフォーマンスを分析するにはどうすればよいですか?説明ステートメントを使用してクエリパフォーマンスを分析するにはどうすればよいですか?Apr 28, 2025 am 12:24 AM

説明ステートメントは、SQLクエリのパフォーマンスを分析および改善するために使用できます。 1.説明ステートメントを実行して、クエリプランを表示します。 2。出力結果を分析し、アクセスの種類、インデックスの使用量に注意し、順序を結合します。 3.分析結果に基づいてインデックスを作成または調整し、結合操作を最適化し、フルテーブルスキャンを回避してクエリ効率を向上させます。

MySQLデータベースをバックアップして復元するにはどうすればよいですか?MySQLデータベースをバックアップして復元するにはどうすればよいですか?Apr 28, 2025 am 12:23 AM

論理バックアップにMySQLDUMPとホットバックアップにMySQLenterPriseBackupを使用することは、MySQLデータベースをバックアップする効果的な方法です。 1. mysqldumpを使用してデータベースをバックアップします:mysqldump-uroot-pmydatabase> mydatabase_backup.sql。 2。ホットバックアップにmysqlenterprisebackupを使用:mysqlbackup - user = root-password = password - backup-dir =/path/to/backupbackup。回復するときは、対応する寿命を使用します

MySQLのスロークエリの一般的な原因は何ですか?MySQLのスロークエリの一般的な原因は何ですか?Apr 28, 2025 am 12:18 AM

MySQLのクエリが遅い主な理由には、インデックスの欠落または不適切な使用、クエリの複雑さ、過剰なデータボリューム、および不十分なハードウェアリソースが含まれます。最適化の提案には以下が含まれます。1。適切なインデックスを作成します。 2。クエリステートメントを最適化します。 3.テーブルパーティションテクノロジーを使用します。 4.適切にハードウェアをアップグレードします。

mysqlのビューは何ですか?mysqlのビューは何ですか?Apr 28, 2025 am 12:04 AM

MySQLビューは、SQLクエリの結果に基づいた仮想テーブルであり、データを保存しません。 1)ビューは複雑なクエリを簡素化し、2)データセキュリティを強化し、3)データの一貫性を維持します。ビューは、テーブルのように使用できるデータベースにクエリを保存しますが、データは動的に生成されます。

MySQLと他のSQL方言の構文の違いは何ですか?MySQLと他のSQL方言の構文の違いは何ですか?Apr 27, 2025 am 12:26 AM

MySQLdiffersfromotherSQLdialectsinsyntaxforLIMIT,auto-increment,stringcomparison,subqueries,andperformanceanalysis.1)MySQLusesLIMIT,whileSQLServerusesTOPandOracleusesROWNUM.2)MySQL'sAUTO_INCREMENTcontrastswithPostgreSQL'sSERIALandOracle'ssequenceandt

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。