MySQL のデータベース パフォーマンスに影響を与える要因の説明

MySQL のデータベース パフォーマンスに影響を与える要因の説明

データベースのパフォーマンスに関する話

面接では、「データベースにどのくらい精通していますか?」など、データベースに関する話題がある程度議論されます。データベースのパフォーマンスが最もテストされるのはいつですか?一般的には、大量のデータを読み書きするときです。電子商取引の大規模なプロモーション活動は、各データベースのパフォーマンスをテストする時期です。

Web サーバーの場合、データ量が多い場合は、水平方向に拡張するだけで単一サーバーの負荷を軽減できます。しかし、データベース サーバーの場合はそれほど簡単ではありません。水平方向に簡単に拡張できず、データベースの整合性と一貫性の原則にも違反します。では、データベース アーキテクチャはどのように構築すればよいのでしょうか。

大規模なプロモーション活動では、どんなに商品が優れていても、企画が成功していても、安定したデータベースやサーバー環境がなければ、すべて無駄になってしまいます。

データベースアーキテクチャの例

図に示すように、マスターサーバーとスレーブサーバーの間にはマスタースレーブレプリケーションコンポーネントがありません。つまり、マスターサーバーに障害が発生した場合、マスターサーバーを切り替えることは困難です。これにより、DBAはスレーブサーバーから最新のデータを持つスレーブサーバーを選択し、それをマスターサーバーに昇格させ、他のスレーブサーバーを同期する必要があります。このプロセスの時間コストも非常に大きくなります。

さらに、ビジネスボリュームが大きい場合、スレーブ サーバーの数が多すぎると、メイン サーバーのネットワーク カードに一定の負担がかかります。

クラスター監視情報を使用すると、データベースのパフォーマンスに影響を与えるものを把握できます。

答えは「はい」です。一般的に言えば、主な理由は QPS と TPS、同時実行性 (同時接続数との混同を避けるため、同時に処理されるリクエストの数)、ディスク IO、読み取り操作が多すぎることです。

ここで提案があります: メイン データベースのデータをバックアップしないこと、少なくとも大規模なアクティビティの前にそのような計画をキャンセルすることが最善です。

データベースに影響を与える要因

  • SQLクエリ速度
  • サーバーハードウェア
  • ネットワークカードのトラフィック
  • ディスクIO

超高QPSとTPS

リスク: 非効率的な SQL (QPS: 1 秒あたりに処理されるクエリ数)

高いCPU使用率と高い同時実行性

リスク: 同時接続数が多い (データベース接続数がいっぱい (max_connections のデフォルトは 100))

リスク: CPU 使用率が非常に高くなる (CPU 枯渇によるダウンタイム)

ディスクIO

リスク: ディスク IO パフォーマンスが突然低下する (より高速なディスク デバイスを使用する)

リスク: ディスクパフォ​​ーマンスを大量に消費するその他のスケジュールされたタスク (スケジュールされたタスクを調整する)

ネットワークカードのトラフィック

リスク: ネットワーク カードの IO がいっぱいです (1000Mb/8=100MB)

データベースに接続できない状況を回避する方法:

1. スレーブサーバーの数を減らす
2. 階層キャッシュを実行する
3. クエリに「select *」を使用しない
4. ビジネスネットワークとサーバーネットワークを分離する

以下もご興味があるかもしれません:
  • MySQL の集計関数 count の使用法とパフォーマンスの最適化テクニック
  • MySQLクエリのパフォーマンスに影響を与える大きなオフセットの理由と最適化の詳細な説明
  • MySQL挿入パフォーマンスを最適化する方法の例
  • MySQL パフォーマンスの包括的な最適化方法リファレンス、CPU、ファイルシステムの選択から mysql.cnf パラメータの最適化まで
  • MySQL と MariaDB の違いについての簡単な説明 (MariaDB と MySQL のパフォーマンス比較)
  • 数千万のデータを扱うMySQLのページングクエリのパフォーマンスを最適化する
  • MySQL ページングパフォーマンスの調査
  • MySQL バッチ SQL 挿入パフォーマンス最適化の詳細な説明
  • MySQL の重要なパフォーマンス インデックスの計算と最適化方法の概要

<<:  Linux の総合システム監視ツール dstat の詳細な例

>>:  Vue が DingTalk の出勤カレンダーを実装

推薦する

HTML 内の CSS および JS リンクのバージョン番号 (キャッシュを更新)

背景検索エンジンで「.htaccess キャッシュ」というキーワードを検索すると、ウェブサイトのファ...

フレックスレイアウトではサブアイテムの高さを維持できる

Flex レイアウトを使用すると、水平に配置すると、すべての子項目の高さが同じになることがわかります...

Linux C ログ出力コード テンプレート サンプル コード

序文この記事は主に Linux C でのログ出力コード テンプレートに関する関連コンテンツを紹介し、...

ランダムロールコールテーブルを実装するためのネイティブJavaScript

この記事では、JavaScriptのランダムロールコールテーブルの具体的なコードを参考までに紹介しま...

nginx共有メモリの仕組みの詳細な説明

Nginx の共有メモリは、高いパフォーマンスを実現できる主な理由の 1 つであり、主にファイル キ...

CSS でテキストカラーグラデーションを実装する 3 つの方法

Web フロントエンド開発のプロセスでは、UI デザイナーはグラデーション テキストを使用したデザイ...

TypescriptとAxiosに基づくインターフェースリクエスト管理の詳細な説明

目次アイデア傍受を要求するレスポンスインターセプションhttpClient.tsを使用してリクエスト...

非ルートユーザーを使用してDockerコンテナでスクリプト操作を実行する

アプリケーションをコンテナ化した後、Docker コンテナを起動すると、デフォルトで root ユー...

CSS3 は、跳ねるボール効果を実現する Web アニメーションを作成します。

基本的な準備この実装には、クラス名が ball である単純な div が必要です。 HTMLコード:...

JavaScript で一意の ID を生成するいくつかの方法

考えられる解決策1. Math.randomは[0,1)の範囲の乱数を生成します。 //今回は生成さ...

ウェブページの読み込み進捗状況バーの詳細な説明(推奨)

(Web ページの読み込み中に、コンテンツが多すぎて読み込みと待機が続くことがあります。このとき、...

nginx における proxy_pass のさまざまな使用法の詳細な説明

目次プロキシ転送ルール最初のもの: 2番目のタイプ: 3番目のタイプ: 4番目のタイプ: 5番目:プ...

JavaScript における BOM と DOM の詳細な説明

目次BOM (ブラウザ オブジェクト モデル) 1. ウィンドウブラウザのウィンドウサイズを取得する...

一般的な Linux の問題に対する解決策の概要

1. VMwareでCentos7を接続し、固定IPを設定する1) まず、仮想イメージ名を右クリック...

MySQL マルチテーブル結合クエリの詳細な説明

目次複数テーブル結合クエリ内部結合左結合右結合サブクエリ要約する複数テーブル結合クエリテーブル間の接...