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 をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: JavaScriptタイマーとボタン効果設定の詳細な説明
ミラーを探すDocker Hubのウェブサイトからイメージを検索できます。Docker Hubのウェ...
「ページのスクリーンショット」は、ページポスターの生成、ポップアップ画像の共有など、フロントエンドで...
VMware Workstation を使用して Windows 10 で仮想マシンを開くと、VMw...
高可用性 Web クラスターを実現する Keepalived+Nginx+Tomcat 1. Ngi...
目次一方向データフローの説明Vue2.x の使用法親コンポーネントに変更を通知するイベントのフォーム...
今日は、Docker イメージ、各レイヤーの内容を調べ、Docker/OCI イメージのサイズを縮小...
MySQL でデータを削除するには 2 つの方法があります。切り詰めは大まかな伐採の一種である削除は...
<br />インターネットは絶えず変化しており、BusinessWeek.com は専門...
通常、コンポーネントのライフサイクルは、ビジネス ロジックが始まる場所です。ビジネスシナリオが複雑で...
ハイパーリンクはインターネット全体を接続していると言っても過言ではありません。ハイパーリンクは、別の...
序文インデックスが順序付けられていることは誰もが知っていると思いますが、MySQL の以前のバージョ...
私はいつも、なぜMySQLデータベースのtimestampタイムゾーンの問題を無視できるのか疑問に思...
1. 一般的な使用法: (1)%で使用する% は 1 つ以上の文字のワイルドカードを表します。たとえ...
CSS によるテキストの切り捨てテキストを自動的に切り捨てるスタイル コードを実装するには、次のコー...
MySQL でデータを削除する方法は 2 つあります。1 つは DELETE ステートメント、もう ...