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を安全にシャットダウンする方法

MySQL サーバーをシャットダウンする場合、シャットダウン方法に応じてさまざまな問題が発生する可能...

Linux カーネル デバイス ドライバーのメモリ管理に関する注意事項

/************************ * Linux メモリ管理 *********...

CSS を使用してプログレスバーと順序プログレスバーを実装する例

この半月、期末試験の準備にかなりのエネルギーを費やしました。今日はしっかり復習するべきだったのですが...

JS で配列の重複排除を実装する 7 つの方法

目次1. Set()+Array.from() を使用する2. 2層ループ+アレイ接合方式の使用3....

Windows 10 システムで nginx ファイル サーバーを構成するためのグラフィック チュートリアル

Nginx の公式 Web サイトから Windows バージョンの Nginx をダウンロードしま...

小さな三角形の実装コードを含む CSS ナビゲーション バー メニュー

多くの Web ページにはナビゲーション バーに小さな三角形があり、この機能を実装するのは実は非常に...

React Nativeプロジェクトフレームワークの構築経験

React Native は、2015 年 4 月に Facebook によってオープンソース化され...

Mysql は null 値の first/last メソッドの例を実装します

序文MySQL が SQL SELECT コマンドと WHERE 句を使用してテーブルからデータを読...

Google 翻訳ツール: 多言語ウェブサイトを素早く実装

Google Chinaは、ウェブサイトやブログを素早く簡単に多言語化できる翻訳ツールをリリースした...

MySQL 学習ノート: データ エンジン

現在のデータベースでサポートされているエンジンを表示します エンジンを表示 +-----------...

Docker を使用してフロントエンド アプリケーションをデプロイする方法

Dockerはますます普及しています。環境を軽量かつ柔軟に分離し、容量を拡張し、運用保守管理を容易に...

MYSQLは、ショッピングカートに追加する際に重複追加を防ぐためのサンプルコードを実装します。

序文最近、仕事の都合で、APP ショッピングカートの注文支払いに取り組んでいました。テスト中にバグが...

あまり使われていない、または誤解されている HTML タグ 10 個

ここでは、あまり使われていない、または誤解されている 10 個の HTML タグを紹介します。あまり...

InnoDB の主な機能 - 挿入キャッシュ、2 度書き込み、適応ハッシュ インデックスの詳細

InnoDB ストレージ エンジンの主な機能には、挿入バッファ、二重書き込み、適応ハッシュインデック...

CSSはフロートをシミュレートして、画像の左右を囲む中央テキストの効果を実現します。

画像の周囲にテキストを折り返すとは何ですか?これは次の図の効果です。 エフェクトのCSSコードはここ...