3つの簡単な調整でMySQLを最適化する

3つの簡単な調整でMySQLを最適化する

私は熟練した DBA になるつもりはありませんが、MySQL を最適化するときは、いくつかの構成を調整するだけで最大 80% のパフォーマンス向上を実現できるという 80/20 ルールを信じています。特に、サーバーのリソースはますます安価になってきています。

警告する

1. 2 つのデータベースやアプリケーションがまったく同じであることはありません。ここでは、チューニングしているデータベースが「典型的な」Web サイトを提供しており、その優先事項は高速なクエリ、優れたユーザー エクスペリエンス、および大量のトラフィックの処理であると想定します。

2. サーバーを最適化する前に、データベースをバックアップしてください。

1. InnoDBストレージエンジンを使用する

まだ MyISAM ストレージ エンジンを使用している場合は、InnoDB に切り替える時期です。 InnoDB が MyISAM よりも有利な理由はたくさんあります。パフォーマンスが気になる場合は、物理メモリの使用方法を見てみましょう。

  • MyISAM: インデックスをメモリ内にのみ保存します。
  • InnoDB: インデックスとデータをメモリに保存します。

結論: メモリに保存されたコンテンツは、ディスクに保存されたコンテンツよりも高速にアクセスできます。

テーブルのストレージ エンジンを切り替える方法は次のとおりです。

ALTER TABLE テーブル名 ENGINE=InnoDB;

注: 適切なインデックスはすべて作成しましたか?パフォーマンスを向上させるには、インデックスの作成を常に最優先にする必要があります。

2. InnoDBにすべてのメモリを使用させる

my.cnf ファイルで MySQL 設定を編集できます。 innodb_buffer_pool_size パラメータを使用して、InnoDB がサーバー上で使用できる物理メモリの量を設定します。

これに関して一般的に受け入れられている「経験則」は (サーバーが MySQL のみを実行していると仮定して)、サーバーの物理メモリの 80% に設定することです。スワップ パーティションを使用せずにオペレーティング システムが正常に動作するのに十分なメモリがあることを確認した後、できるだけ多くの物理メモリを MySQL に割り当てます。

したがって、サーバーの物理メモリが 32 GB の場合、そのパラメータを最大 25 GB に設定できます。

innodb_buffer_pool_size = 25600M

*注: (1) サーバーのメモリが小さく、1 GB未満の場合。この記事の方法を使用するには、サーバーをアップグレードする必要があります。 (2)サーバーのメモリ容量が200GBなどの大容量の場合、常識的に考えて、オペレーティングシステム用に最大40GBのメモリを予約する必要はありません。 *

3. InnoDBを複数のタスクで実行できるようにする

サーバーのパラメータinnodb_buffer_pool_size 1 GB より大きく設定されている場合、InnoDB バッファ プールはパラメータ innodb_buffer_pool_instances の設定に従って複数のインスタンスに分割されます。

複数のバッファ プールを持つことの利点は次のとおりです。

複数のスレッドが同時にバッファ プールにアクセスすると、ボトルネックが発生する可能性があります。複数のバッファ プールを有効にすることで、この競合を最小限に抑えることができます。

バッファ プールの数に関する公式の推奨事項は次のとおりです。

最良の結果を得るには、innodb_buffer_pool_instances と innodb_buffer_pool_size の設定を考慮して、各インスタンスに少なくとも 1 GB のバッファー プールがあることを確認してください。

したがって、この例では、32 GB の物理メモリを搭載したサーバー上で、パラメータ innodb_buffer_pool_size は 25 GB に設定されています。適切な設定は25600M / 24 = 1.06 GBです。

innodb_buffer_pool_instances = 24

知らせ!

my.cnf ファイルを変更した後、変更を有効にするには MySQL を再起動する必要があります。

sudo サービス mysql を再起動

これらのパラメータを最適化するにはより科学的な方法もありますが、これらのポイントは MySQL サーバーのパフォーマンスを向上させるための一般的なガイドラインとして適用できます。

要約する

上記は、私がご紹介した MySQL を最適化するための 3 つの簡単な調整です。お役に立てれば幸いです。ご質問がある場合は、メッセージを残していただければ、すぐに返信いたします。また、123WORDPRESS.COM ウェブサイトをサポートしてくださっている皆様にも感謝申し上げます。

以下もご興味があるかもしれません:
  • MySQL 4G メモリ サーバー構成の最適化
  • MYSQL開発パフォーマンス調査:バッチデータ挿入の最適化方法
  • MySQL の基本ステートメントを最適化するための 10 の原則の概要
  • MySQLが大量のデータを処理する際にクエリ速度を最適化するいくつかの方法
  • Mysql が CPU を過剰に占有する場合の最適化方法 (必読)
  • MySQL 最適化: キャッシュ最適化
  • MySQL の最適化: InnoDB の最適化
  • MySQL でレコードを挿入する速度を最適化する方法
  • MySQL 最適化ツールについての簡単な説明 - 遅いクエリ

<<:  Linux環境でのActiveMQ導入方法の詳しい説明

>>:  JS ネイティブ 2048 ゲーム ソース コード共有 (インターネットの最新情報)

推薦する

MySQL での実行計画の詳細分析

序文効率的なSQL文の書き方は、Explain実行計画の分析と切り離せません。実行計画とは何か、効率...

CSS を使用して要素のスクロールバーを非表示にするサンプルコード

どの要素でもスクロールできるようにしながら、スクロールバーを非表示にするにはどうすればよいでしょうか...

MySQL のインデックス有効条件とインデックス無効条件の結合

目次1. ジョイントインデックスの故障の条件2. インデックス失敗の条件1. ジョイントインデックス...

ウェブページでよく使用される共有コードの完全なリスト(フロントエンドに必須)

コードをコピーコードは次のとおりです。 1. 新浪微博<a href="http:/...

IE9 のネイティブ ページ互換性の問題に対する解決策についての簡単な説明

序文最近、クライアントのネイティブページを引き継ぎました。顧客は、ページが IE9 以降のバージョン...

ローカルアイデアアクティベーションサーバーの構築に関する詳細なチュートリアル

序文ブロガーはアイデアIDEを使用しています。アイデア公式が最近サードパーティのアクティベーションサ...

JavaScript ウェブページ入門開発詳細説明

パート3: ❤バックエンドデータ受信を見落とす3つの方法❤ (おすすめ集)パート 2: Web フォ...

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

よく食べて十分に休息を取るというのは簡単なことのように思えますが、実際に実行するのはそれほど簡単では...

vue ディレクティブ v-bind の使用と注意点

目次1. v-bind: 要素の属性にデータをバインドできる2. v-bind: は次のように省略で...

CSSはラジオをクリックして2つの画像スタイルを切り替えますが、複数のラジオのうち1つだけをチェックできます。

クリックされたボタンには赤い画像スタイルを実装し、選択されていない他のボタンには灰色の画像スタイルを...

この記事では、MySQLのマスタースレーブ同期の原理を説明します。

目次MySQL マスタースレーブ同期原理の簡単な分析1. マスタースレーブとは何ですか? 2. 主従...

element.style インライン スタイルを変更する方法のチュートリアル

序文上記の Web ページ スタイルを記述しているときに、スタイルの値をどのように変更しても、ページ...

MySQL 5.7 のキーワードと予約語の詳細な説明

序文MySQL と Oracle のキーワードはまったく同じではありません。Oracle データベー...

CSSは左固定と右適応のレイアウト方法を実現します

1. フローティングレイアウト1. 最初に固定幅の div をフロートさせます。ドキュメントフローか...