MySQL データベースのマスター・スレーブ レプリケーションと読み取り/書き込み分離

MySQL データベースのマスター・スレーブ レプリケーションと読み取り/書き込み分離

1. マスタースレーブレプリケーション

マスタースレーブレプリケーション: 実際の運用では、MySQL の単一障害点を解決し、MySQL の全体的なサービスパフォーマンスを向上させるために、マスタースレーブレプリケーションが一般的に使用されます。つまり、データベース内のデータとステートメントをバックアップします。

ここに画像の説明を挿入

マスタースレーブレプリケーション3スレッド

MySQL のマスター スレーブ レプリケーションには、マスター (バイナリ ログ ダンプ スレッド)、スレーブ (I/O スレッド、SQL スレッド)、マスターに 1 つのスレッド、スレーブに 2 つのスレッドという 3 つのメイン スレッドがあります。

マスタースレーブレプリケーションプロセス

マスタースレーブレプリケーションのプロセス:

マスターの主な役割は、マスター ライブラリでデータの更新があった場合に、更新されたイベント タイプを binlog 形式でマスター ライブラリの binlog ファイルに書き込むことです。マスターはログ ダンプ スレッドを作成し、メイン データベースにデータ更新があることをスレーブに通知します。

I/O スレッドはスレーブで作成され、マスターに要求するために使用されます。マスターは、バイナリログの名前、現在のデータ更新の場所、およびバイナリログ ファイルの場所のコピーを返します。次に、バイナリログはリレーログに保存され、データの更新に関する情報も記録されます。

SQL スレッドはスレーブにも作成されます。スレーブはリレー ログが更新されたことを検出すると、更新された内容をスレーブ データベースに同期し、マスターとスレーブのデータの同期を確実にします。

マスタースレーブレプリケーション戦略

マスタースレーブレプリケーション戦略:

同期戦略: マスターはコミットする前にすべてのスレーブが応答するのを待機します。これは、マスターとスレーブの同期のパフォーマンスに重大な影響を及ぼします。

半同期戦略: マスターはコミットする前に少なくとも 1 つのスレーブが応答するのを待ちます。

非同期戦略: マスターはスレーブの応答を待たずに送信できます。

遅延戦略: スレーブはマスターによって指定された時間より遅れる必要があります。
ビジネス ニーズに応じてさまざまな戦略がありますが、一般的には最終的な一貫性が採用され、強い一貫性はパフォーマンスに重大な影響を与えるため、強い一貫性は必要ありません。

マスタースレーブレプリケーションにおける高レイテンシ

マスタースレーブレプリケーションにおける高レイテンシの理由

マスターサーバーは同時実行性が高く、多数のトランザクションが発生する

ネットワーク遅延

マスターおよびスレーブ ハードウェア デバイス (CPU メイン周波数、メモリ IO、ハード ディスク IO) によって発生します。

これは同期レプリケーションではなく、非同期レプリケーションです。

マスタースレーブレプリケーションの高レイテンシに対するソリューション

データベースからMysqlパラメータを最適化します。たとえば、innodb_buffer_pool_sizeを増やすと、より多くの操作がmysqlメモリ内で完了し、ディスク操作が削減されます。

データベースから高性能ホスト(高性能CPU、大容量メモリ)を使用し、仮想クラウドホストの使用を避け、物理ホストを使用してI/Oスループットを向上させる

ライブラリのSSDディスクを使用する

コンピュータルーム間の同期を回避するためのネットワーク最適化

2. 読み取りと書き込みの分離

ここに画像の説明を挿入

読み取りと書き込みの分離の概念

読み取り/書き込みの分離: 読み取り/書き込みの分離により、プライマリ データベースはトランザクションの追加、削除、および変更操作 (INSERT、UPDATE、DELETE) を処理し、セカンダリ データベースはクエリ (SELECT) 操作を処理できます。データベース レプリケーションは、トランザクション操作によって発生した変更をクラスター内のスレーブ データベースに同期するために使用されます。

読み取りと書き込みを分離する理由とシナリオ

読み取りと書き込みを分離する理由: 読み取りと書き込みの量が多い。データベースの読み取りと書き込みのパフォーマンスを向上させるために、読み取りと書き込みを分離します。複数のコンピュータ ルームで読み取りが書き込みよりも多い場合、データの一貫性を考慮して、1 つのマスター データベースのみがすべてのデータ書き込みを保存し、ローカル スレーブ データベースが読み取りを提供して、複数のコンピュータ ルーム間の直接読み取りによって発生する遅延を減らします。

読み取り/書き込み分離の使用シナリオ: プログラムがデータベースをより頻繁に使用するが、更新は少なく、クエリは多い場合に考慮されます。データベースのマスター/スレーブ同期と読み取り/書き込み分離を使用することで、データベースの負荷を分散し、パフォーマンスを向上させることができます。

要約する

これで、MySQL データベースのマスター スレーブ レプリケーションと読み取り/書き込み分離に関するこの記事は終了です。MySQL マスター スレーブ レプリケーションと読み取り/書き込み分離の詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL マスタースレーブレプリケーション遅延問題の詳細な説明
  • MySQL マスタースレーブレプリケーションにおける重複キーの問題を修正する方法
  • MySQLのマスタースレーブレプリケーションと読み取り書き込み分離を理解するための記事
  • MySQLデータベースのマスタースレーブレプリケーションと読み取り書き込み分離に関する詳細なチュートリアル
  • MySQL マスタースレーブレプリケーションの GTID モードの詳細な紹介
  • MySQL マスターとスレーブのレプリケーション間のデータの不一致に対する解決策
  • MySQL マスタースレーブレプリケーションの問題の概要とトラブルシューティング

<<:  JavaScriptタイマーとボタン効果設定の詳細な説明

>>:  HTML ページに SVG を挿入する複数の方法

推薦する

主キーを追加または変更するMySQL SQL文操作

テーブルフィールドを追加する テーブルtable1を変更し、トランザクタvarchar(10)をNu...

純粋な CSS カスタム複数行省略記号の問題 (原理から実装まで)

テキストオーバーフローを表示するにはどうすればいいですか? どのようなニーズがありますか?単一行です...

Linux inotifyリアルタイムバックアップの実装方法の詳細説明

リアルタイム レプリケーションは、企業データをバックアップする最も重要な方法です。主に、ユーザーが送...

ウェブページのコピー防止機能の実装方法(クラッキング手法付き)

ソース ファイルを右クリックすると、次のコードが見つかります。 1. CSSを使用してFirefox...

プライベートウェアハウス(レジストリとハーバー)を構築するためのDockerの実装

使用される Docker イメージが増えるにつれて、イメージを保存する場所、つまりウェアハウスが必要...

MySQL データベースの基礎を始めるための一般的なコマンドの概要

この記事では、MySQL データベースの基礎を学ぶためによく使用されるコマンドを例を使って説明します...

CSS 標準: vertical-align プロパティ

<br />原文: http://www.mikkolee.com/13私は最近、ver...

Dockerは複数のポートマッピングコマンドを有効にします

次のように: docker run -d -p 5000:23 -p 5001:22 --name ...

HTML文書の基本構造(Webページ作成の基礎知識)

HTMLの動作原理: 1. ローカル操作: ブラウザでhtmlファイルを開く2. リモートアクセス...

MySQL ストアド プロシージャ (in、out、inout) の詳細な説明

1. はじめにバージョン 5.0 以降でサポートされています。特定の機能を実行するための SQL ス...

MySQL 8.0.20 インストール チュートリアル (画像とテキスト付き) (Windows 64 ビット)

1: mysql公式サイトからダウンロードhttps://dev.mysql.com/downlo...

Linux teeコマンドの使い方の詳しい説明

teeコマンドは主にstandout(標準出力ストリーム、通常はコマンド実行ウィンドウ)に出力し、同...

5分でWebRTCビデオチャットを構築する

前回の記事では、Ubuntu 上の webrtc ベースの多人数ビデオチャット サービスの詳細なコー...

HTML の doctype とエンコーディングに関する簡単な説明

文書タイプDoctype は、指示を解析するためにどのバージョンの HTML を使用するかをブラウザ...

WeChatミニプログラム公式顔認証の詳しい説明

ミニプログラムはユーザーの個人情報を収集してアップロードしましたが、拒否されました。こんにちは、ミニ...