ホームページ システムチュートリアル Linux mysqlのマスタースレーブ遅延を解決する方法

mysqlのマスタースレーブ遅延を解決する方法

Mar 19, 2024 am 09:28 AM
linux Linuxチュートリアル レッドハット Linuxシステム Linuxコマンド ネット障害 Linux 認定 レッドハットリナックス Linuxビデオ

mysqlのマスタースレーブ遅延を解決する方法

MySQL の組み込みレプリケーション機能は、大規模で高性能なアプリケーションを構築するための基盤です。 MySQL データを複数のシステムに分散するこの分散メカニズムは、特定の MySQL ホストのデータを他のホスト スレーブにコピーし、再実行することで実現されます。
レプリケーション中、1 つのサーバーがマスターとして機能し、1 つ以上の他のサーバーがスレーブとして機能します。マスターはバイナリ ログ ファイルに更新を書き込み、ログ ローテーションを追跡するためにファイルのインデックスを維持します。これらのログは、スレーブ サーバーに送信された更新を記録します。スレーブはマスターに接続すると、スレーブがログから読み取った最後に成功した更新の場所をマスターに通知します。スレーブ サーバーは、それ以降に発生した更新を受信し、ブロックしてマスター サーバーから更新が通知されるのを待ちます。
Mysql マスター/スレーブ レプリケーションの問題:

  • メインデータベースがダウンすると、データが失われる可能性があります
  • スレーブ ライブラリには SQL スレッドが 1 つしかなく、メイン ライブラリには大きな書き込みプレッシャーがかかっているため、レプリケーションが遅れる可能性があります。
以下は、mysql のマスター/スレーブ遅延を 4 つの側面から解決する方法についての説明です。
1. MySQL データベースのマスター/スレーブ同期の遅延原理。
回答: MySQL データベースのマスター/スレーブ同期遅延の原理について話すときは、mysql データベースのマスター/スレーブ レプリケーションの原理から始める必要があります。mysql のマスター/スレーブ レプリケーションはシングルスレッド操作です。メイン データベースは、すべての DDL と DML の binlog と binlog を生成します。これはシーケンシャルに書き込まれるため、効率が非常に高くなります。スレーブの Slave_IO_Running スレッドはログを取得するためにメイン ライブラリに移動し、効率は比較的高くなります。スレーブの Slave_SQL_Runningスレッドは、メイン ライブラリのすべての DDL および DML 操作をスレーブ上に実装します。 DML と DDL の IO 操作はランダムであり、シーケンシャルではないため、コストが非常に高くなります。スレーブ上の他のクエリもロック競合を引き起こす可能性があります。Slave_SQL_Running もシングルスレッドであるため、DDL カード マスターは 10 回実行する必要があります。分が経過すると、後続のすべての DDL は、この DDL の実行が完了するまで待機してから続行するため、遅延が発生します。 「メイン ライブラリの同じ DDL も 10 分間実行する必要があります。なぜスレーブが遅れるのですか?」と尋ねる友人もいます。その答えは、マスターは同時に実行できますが、Slave_SQL_Running スレッドは実行できないからです。

2. MySQL データベースにおけるマスターとスレーブの同期の遅延はどのようにして発生しますか?
回答: メイン ライブラリの TPS 同時実行性が高い場合、生成される DDL 数がスレーブの 1 つの SQL スレッドが耐えられる範囲を超えて遅延が発生します。スレーブの大きなクエリ ステートメントです。お待​​ちください。

3.MySQL データベースのマスター/スレーブ同期遅延ソリューション

回答: スレーブ同期遅延を軽減する最も簡単な解決策は、アーキテクチャを最適化し、メイン ライブラリの DDL を高速に実行するように努めることです。メイン ライブラリが sync_binlog=1、innodb_flush_log_at_trx_commit = 1 などの高いデータ セキュリティを備えて記述されているという事実もありますが、スレーブにはそのような高いデータ セキュリティは必要ありません。sync_binlog を 0 またはSQL の実行効率を向上させるために、innodb_flushlog を 0 に設定することもできます。もう 1 つは、メイン ライブラリよりも優れたハードウェア デバイスをスレーブとして使用することです。

4. MySQL データベースのマスター/スレーブ同期の遅延要因。

1.ネットワーク遅延
2.マスターロード
3. スレーブロード
一般的なアプローチは、複数のスレーブを使用して読み取りリクエストを分散し、これらのスレーブの専用サーバーをバックアップのみに使用し、他の操作は行わないことで、「リアルタイム」要件を最大限に達成できます。

さらに、遅延を軽減できるパラメータをさらに 2 つ導入します


–slave-net-timeout=秒 パラメータの意味: スレーブがメイン データベースからのログ データの読み取りに失敗した場合、接続を再確立してデータを取得するまでの待ち時間
smile_net_timeout の単位は秒で、デフォルト設定は 3600 秒です。
| スレーブネットタイムアウト | 3600
–マスター接続再試行=秒
パラメータの意味: マスターとスレーブの接続を再確立するときに、接続の確立に失敗した場合、再試行にかかる時間。 master-connect-retry の単位は秒で、デフォルト設定は 60 秒です。 通常、上記の 2 つのパラメータを設定すると、ネットワークの問題によるマスターとスレーブのデータ同期の遅延を軽減できます

以上がmysqlのマスタースレーブ遅延を解決する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

VSCODEに必要なコンピューター構成 VSCODEに必要なコンピューター構成 Apr 15, 2025 pm 09:48 PM

VSコードシステムの要件:オペレーティングシステム:オペレーティングシステム:Windows 10以降、MACOS 10.12以上、Linux Distributionプロセッサ:最小1.6 GHz、推奨2.0 GHz以上のメモリ:最小512 MB、推奨4 GB以上のストレージスペース:最低250 MB以上:その他の要件を推奨:安定ネットワーク接続、XORG/WAYLAND(Linux)

Linuxアーキテクチャ:5つの基本コンポーネントを発表します Linuxアーキテクチャ:5つの基本コンポーネントを発表します Apr 20, 2025 am 12:04 AM

Linuxシステムの5つの基本コンポーネントは次のとおりです。1。Kernel、2。Systemライブラリ、3。Systemユーティリティ、4。グラフィカルユーザーインターフェイス、5。アプリケーション。カーネルはハードウェアリソースを管理し、システムライブラリは事前コンパイルされた機能を提供し、システムユーティリティはシステム管理に使用され、GUIは視覚的な相互作用を提供し、アプリケーションはこれらのコンポーネントを使用して機能を実装します。

vscode端子使用チュートリアル vscode端子使用チュートリアル Apr 15, 2025 pm 10:09 PM

VSCODEビルトインターミナルは、エディター内でコマンドとスクリプトを実行して開発プロセスを簡素化できるようにする開発ツールです。 VSCODE端子の使用方法:ショートカットキー(CTRL/CMD)で端子を開きます。コマンドを入力するか、スクリプトを実行します。 Hotkeys(Ctrl Lなどの端子をクリアするなど)を使用します。作業ディレクトリ(CDコマンドなど)を変更します。高度な機能には、デバッグモード、自動コードスニペット完了、およびインタラクティブコマンド履歴が含まれます。

GITの倉庫アドレスを確認する方法 GITの倉庫アドレスを確認する方法 Apr 17, 2025 pm 01:54 PM

gitリポジトリアドレスを表示するには、次の手順を実行します。1。コマンドラインを開き、リポジトリディレクトリに移動します。 2。「git remote -v」コマンドを実行します。 3.出力と対応するアドレスでリポジトリ名を表示します。

vscodeでコードを書く場所 vscodeでコードを書く場所 Apr 15, 2025 pm 09:54 PM

Visual Studioコード(VSCODE)でコードを作成するのはシンプルで使いやすいです。 VSCODEをインストールし、プロジェクトの作成、言語の選択、ファイルの作成、コードの書き込み、保存して実行します。 VSCODEの利点には、クロスプラットフォーム、フリーおよびオープンソース、強力な機能、リッチエクステンション、軽量で高速が含まれます。

Apr 16, 2025 pm 07:39 PM

NotePadはJavaコードを直接実行することはできませんが、他のツールを使用することで実現できます。コマンドラインコンパイラ(Javac)を使用してByteCodeファイル(filename.class)を生成します。 Javaインタープリター(Java)を使用して、バイトコードを解釈し、コードを実行し、結果を出力します。

Linuxの主な目的は何ですか? Linuxの主な目的は何ですか? Apr 16, 2025 am 12:19 AM

Linuxの主な用途には、1。Serverオペレーティングシステム、2。EmbeddedSystem、3。Desktopオペレーティングシステム、4。開発およびテスト環境。 Linuxはこれらの分野で優れており、安定性、セキュリティ、効率的な開発ツールを提供します。

コードを書いた後に崇高に実行する方法 コードを書いた後に崇高に実行する方法 Apr 16, 2025 am 08:51 AM

Sublimeでコードを実行するには6つの方法があります。ホットキー、メニュー、ビルドシステム、コマンドライン、デフォルトビルドシステムの設定、カスタムビルドコマンド、プロジェクト/ファイルを右クリックして個々のファイル/プロジェクトを実行します。ビルドシステムの可用性は、崇高なテキストのインストールに依存します。

See all articles