ホームページ >データベース >mysql チュートリアル >MySQL データベースの最適化に関する知識は何ですか?
データベースの最適化は、システムのボトルネックを特定し、MySQL データベース全体のパフォーマンスを向上させることである一方で、ユーザーの応答速度を向上させるために合理的な構造設計とパラメーターの調整が必要であると同時に、ユーザーがシステムに大きな負荷を与えることができるように、システム リソースをできる限り節約することも必要です。
著者は、最適化をソフト最適化とハード最適化の 2 つのカテゴリに分類しており、一般にソフト最適化にはデータベースの操作が含まれ、ハード最適化にはサーバー ハードウェアの操作とパラメーター設定が含まれます。 2.1 ソフトの最適化
DESC SELECT * FROM `user`
見せる:############### インデックス数やクエリデータの読み込みデータなどの情報が表示されます。
2.1.2 サブクエリの最適化
MySQL では、サブクエリの代わりに JOIN を使用してみてください。サブクエリにはネストされたクエリが必要であるため、クエリをネストすると一時テーブルが作成されます。一時テーブルの作成と削除には大きなシステム オーバーヘッドがかかりますが、結合クエリではテーブルが作成されません。一時テーブルなので、ネストされたサブクエリよりも効率的です。
2.1.3 インデックスの使用## インデックス作成は、データベース クエリの速度を向上させる最も重要な方法の 1 つです。インデックス作成については、著者の記事
を参照して詳細を確認してください。インデックスを使用する際の 3 つの主な注意事項を次に示します:2. このクエリでインデックスを使用する前に、OR キーワードの両方のフィールドにインデックスを付ける必要があります。
2.1.4 分解表
2.1.5 中間テーブル
クエリに多数の接続が必要なテーブルの場合は、クエリ中に消費される接続時間を短縮するために中間テーブルを作成できます。
2.1.6 冗長フィールドの追加
2.1.7 分析テーブル、チェックテーブル、最適化テーブル
Msg_text: 情報を表示します。
などの CHECK キーワードを使用します。 このオプションは MyISAM に対してのみ有効で、合計 5 つのパラメータ値が指定されます:
クイック: ラインをスキャンしたり、接続不良をチェックしたりしないでください。
変更済み: 前回のチェック以降に変更されたテーブルと、正しく閉じられていないテーブルのみをチェックします。
中: 行をスキャンして、削除された接続が有効であることを確認し、各行のキーワード チェックサムも計算します。
拡張: 最も包括的な検査、各行のキーワードの包括的な検索。
などの OPTIMIZE キーワードを使用します。 LOCAL|NO_WRITE_TO_BINLOG は、ログに書き込まないことを意味します。最適化されたテーブルは、VARCHAR、BLOB、および TEXT に対してのみ有効です。ファイルの断片化は OPTIMIZE TABLE ステートメントによって排除でき、実行中に読み取り専用ロックが追加されます。
2.2.1 3 ピースのハードウェア セット
3. 高速ディスクを構成するか、ディスクを合理的に分散します。高速ディスクは I/O を向上させ、分散ディスクは並列操作の能力を向上させることができます。 2.2.2 データベースパラメータの最適化
key_buffer_size: インデックスバッファサイズ
データベースに過大な負荷がかかるため、最初の問題は、過度のデータベース負荷がパフォーマンスに影響を与えるため、ピーク時にシステムのパフォーマンスが低下する可能性があることです。もう 1 つは、過度の圧力によりデータベースがクラッシュした場合はどうすればよいでしょうか?したがって、この時点では、システムをデータベースとテーブルに分割し、読み取りと書き込みを分離する、つまり、1 つのデータベースを複数のデータベースに分割し、複数のデータベース サービスにデプロイする必要があります。このとき、データベースはメイン データベースとして機能します。書き込みリクエストを処理します。次に、各マスター ライブラリが少なくとも 1 つのスレーブ ライブラリをマウントし、スレーブ ライブラリが読み取り要求を処理します。
ユーザー数が増加した場合は、マシンを追加し続けることができます。たとえば、システム レベルでマシンを追加し続けると、より多くの同時リクエストを処理できるようになります。その後、データベース レベルでの書き込み同時実行性がますます高くなると、データベース サーバーが拡張され、サブデータベースとテーブルのシャーディングによってマシンが拡張され、データベース レベルでの読み取り同時実行性がますます高くなると、容量が増加します。拡張され、さらにスレーブ データベースが追加されます。しかし、ここには大きな問題があります。データベース自体は、実際には大量の同時リクエストを処理するために使用されていないため、一般的に言えば、1 台のデータベース マシンが実行する同時実行数は 1 秒あたり数千のオーダーであり、データベースで使用されるマシンは比較的高構成で比較的高価なマシンでは、コストが非常に高くなります。単純にマシンを追加し続けるのは実際には間違っています。したがって、キャッシュは通常、高同時実行性のアーキテクチャに組み込まれており、キャッシュ システムは高い同時実行性を実現するように設計されています。したがって、単一マシンが実行する同時実行の量は 1 秒あたり数万、場合によっては数十万に達し、高同時実行の実行能力はデータベース システムの実行能力よりも 1 ~ 2 桁高くなります。したがって、書き込みが少なく読み取りが多いリクエストに対して、システムのビジネス特性に応じてキャッシュ クラスターを完全に導入できます。具体的には、データベースに書き込むときに、データのコピーが同時にキャッシュ クラスターに書き込まれ、キャッシュ クラスターが読み取りリクエストのほとんどを処理するために使用されます。この場合、キャッシュ クラスタリングを通じて、より少ないマシン リソースを使用して、より高い同時実行性をホストできます。
以上がMySQL データベースの最適化に関する知識は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。