MySQLマスタースレーブデータベース構築方法の詳細な説明

MySQLマスタースレーブデータベース構築方法の詳細な説明

この記事では、MySQL マスター/スレーブ データベースの構築方法について説明します。ご参考までに、詳細は以下の通りです。

マスタースレーブサーバーは、MySQL のリアルタイムデータ同期とバックアップに非常に適したソリューションです。現在、大規模、中規模、小規模のすべての Web サイトは、MySQL データベースのマスタースレーブサーバー機能を使用して、Web サイトデータベースの非同期バックアップを実行しています。ここで、マスタースレーブサーバーの構成手順を紹介します。

MySQL マスタースレーブ レプリケーションには、少なくとも 2 つの MySQL サービスが必要です。もちろん、MySQL サービスを異なるサーバーに分散することも、1 つのサーバーで複数のサービスを開始することもできます。

(1)まず、マスターサーバーとスレーブサーバーのMySQLバージョンが同じであることを確認する

(2)マスターサーバー上でスレーブデータベースアカウントを設定し、次のようにREPLICATION SLAVEを使用して権限を付与します。

mysql> 'slave001'@'192.168.0.99' に *.* のレプリケーションスレーブを許可します。
'123456';
クエリは正常、影響を受けた行は 0 行 (0.13 秒)

(3)メインデータベースの設定ファイルmy.cnfを変更し、BINLOGを有効にし、server-idの値を設定します。変更後、MySQLサービスを再起動する必要があります。

[mysqld]
ログ bin = /home/mysql/log/mysql-bin.log
サーバーID=1

(4) 次に、マスター サーバーの現在のバイナリ ログ名とオフセットを取得します。この操作の目的は、スレーブ データベースの起動後にこの時点からデータを回復することです。

mysql> マスターステータスを表示します。
************************** 1. 行 ****************************
ファイル:mysql-bin.000003
ポジション: 243
バイナリログ_Do_DB:
バイナリログを無視:
セット内の 1 行 (0.00 秒)

(5) これで、マスターデータの更新を停止し、マスターデータベースのバックアップを生成できます。mysqldump を使用して、データをスレーブデータベースにエクスポートできます。もちろん、cp コマンドを使用してデータファイルをスレーブデータベースに直接コピーすることもできます。

データの一貫性を確保するために、データをエクスポートする前にプライマリ データベースを READ LOCK する必要があることに注意してください。

mysql> 読み取りロック付きのテーブルをフラッシュします。
クエリは正常、影響を受けた行は 0 行 (0.19 秒)

次にmysqldump

mysqldump -h127.0.0.1 -p3306 -uroot -p テスト > /home/chenyz/test.sql

プライマリ データベースをバックアップした後、書き込み操作を復元するのが最適です。

mysql> テーブルのロックを解除します。
クエリは正常、影響を受けた行は 0 行 (0.28 秒)

(6)マスターデータのバックアップからtest.sqlファイルをスレーブデータベースにコピーし、インポートします。

(7)次に、スレーブデータベースのmy.cnfファイルを変更し、server-idパラメータを追加し、レプリケーションに使用するユーザー、マスターデータベースサーバーのIPとポート、およびレプリケーションログを実行するファイルと場所を指定します。

[mysqld]
サーバーID=2
log_bin = /var/log/mysql/mysql-bin.log
マスターホスト =192.168.1.100
マスターユーザー=テスト
マスターパス=123456
マスターポート =3306
マスター接続再試行=60
複製-do-db =テスト

(8)スレーブサーバー上でスレーブプロセスを起動する

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

(9) show salve statusを実行してスレーブサーバーを確認する

mysql> スレーブステータスを表示 G
************************** 1. 行 ****************************
Slave_IO_State: マスターがイベントを送信するのを待機中
マスターホスト: ローカルホスト
マスターユーザー: ルート
マスターポート: 3306
接続再試行: 3
マスターログファイル:mysql-bin.003
読み取りマスターログ位置: 79
リレーログファイル: gbichot-relay-bin.003
リレーログ位置: 548
リレーマスターログファイル:mysql-bin.003
スレーブIO実行中: はい
スレーブSQL実行中: はい

(10)これで、マスターサーバー上でいくつかの更新操作を実行し、スレーブサーバー上で更新が完了したかどうかを確認できます。

MySQL 関連のコンテンツに興味のある読者は、このサイトの次のトピックをチェックしてください: 「MySQL クエリ スキル」、「MySQL トランザクション操作スキル」、「MySQL ストアド プロシージャ スキル」、「MySQL データベース ロック関連スキルの概要」、および「MySQL 共通関数の概要」

この記事が皆様のMySQLデータベース設計に役立つことを願っています。

以下もご興味があるかもしれません:
  • Docker コンテナを使用して MySql マスター スレーブ レプリケーションを構築する
  • MySQL 5.7.18 マスタースレーブレプリケーション設定(マスター 1 台とスレーブ 1 台)チュートリアルの詳細な説明
  • MySQL 5.7 Docker のマスタースレーブレプリケーションアーキテクチャの構築に関するチュートリアル
  • MySQL マスタースレーブレプリケーションの読み書き分離構造の詳細な説明
  • Docker ベースの MySQL マスタースレーブレプリケーション環境を構築するための実装手順
  • MySQL マスタースレーブ構築(複数のマスターと 1 つのスレーブ)の実装アイデアと手順

<<:  Dockerを使用してLaravelおよびVueプロジェクトの開発環境を構築する詳細な説明

>>:  Vue.js ソースコード解析のカスタム手順の詳細な説明

推薦する

LinuxにNginxをインストールする詳細な手順

1. Nginxのインストール手順1.1 公式サイトの紹介http://nginx.org/en/d...

Dockerコンテナ起動時に固定IPを設定する実装

Dockerインストール後のネットワークタイプ [root@insure updev]# docke...

エレガントなJSコードの書き方

目次変数意味があり発音しやすい変数名を使用する同じ型の変数には同じ語彙を使用する検索可能な名前を使用...

MySQL 変数宣言とストアド プロシージャの分析

変数の宣言グローバル変数の設定@a='新しい変数' を設定します。関数やストアドプロ...

HTMLでのフォーム送信の実装

フォーム送信コード1. ソースコード分析 <!DOCTYPE html> <htm...

1つの記事でTypeScriptのデータ型について学ぶ

目次基本タイプあらゆるタイプ配列タプルインタフェース関数自己推論を入力する結合タイプ(1つ以上選択)...

Flask アプリケーションの Docker デプロイ実装手順

1. 目的Flask アプリケーションをローカルで作成し、Docker でパッケージ化し、独自のサー...

WeChatアプレットはウォーターフォールフローのページングスクロール読み込みを実装します

この記事では、WeChatアプレットのウォーターフォールフローページングスクロールロードを実装するた...

開発にVscodeとdockerを組み合わせて使用​​する詳細なプロセス

序文Docker と VS Code を使用すると、ローカル開発環境全体を最適化し、プロジェクトの進...

jQueryはシンプルなポップアップウィンドウ効果を実装します

この記事では、簡単なポップアップウィンドウ効果を実現するためのjQueryの具体的なコードを参考まで...

docker runとstartの違い

docker における実行と開始の違いDocker run はミラーイメージを指定します。そしてdo...

VueのVuexの4つの補助機能について

目次1. 補助機能2. 例1. mapState と mapGetters 2. mapMutati...

CSS は Alibaba ベクター ライブラリを使用して、対応する位置に見栄えの良いアイコン効果をすばやく追加します (サンプル コード)

Alibaba ベクターアイコンライブラリにアクセスAlibaba ベクターアイコンライブラリ好き...

JavaScript 配列のマージのケーススタディ

方法1: var a = [1,2,3]; var b = [4,5] b を連結します。 コンソー...

Vueは秒殺しのカウントダウンコンポーネントを実装する

この記事では、2番目のキルカウントダウンコンポーネントを実装するためのVueの具体的なコードを参考ま...