MySQL 最適化: キャッシュ最適化 (続き)

MySQL 最適化: キャッシュ最適化 (続き)

MySQL 内部には至るところにキャッシュがあります。MySQL のソースコードを読むと、キャッシュがどのように使用されているかを詳細に分析します。このセクションでは主に、さまざまな明示的なキャッシュを最適化します。

  1. クエリキャッシュの最適化
  2. 結果セットキャッシュ
  3. ソートキャッシュ
  4. 接続キャッシュに参加する
  5. テーブルキャッシュ キャッシュとテーブル構造定義キャッシュ キャッシュ
  6. テーブルスキャンバッファ
  7. MyISAM インデックス キャッシュ バッファ
  8. ログキャッシュ
  9. 先読みメカニズム
  10. 遅延テーブルと一時テーブル

1. クエリキャッシュの最適化

クエリ キャッシュは、クエリ ステートメントの構造をキャッシュするだけでなく、クエリの結果もキャッシュします。一定期間内に SQL が同じ場合は、結果がキャッシュから直接読み取られ、データの検索効率が向上します。しかし、キャッシュ内のデータがハードディスク上のデータと一致しない場合、キャッシュは無効になります。

mysql> '%query_cache%' のような変数を表示します。
+------------------------------+---------+
| 変数名 | 値 |
+------------------------------+---------+
| クエリキャッシュがある | はい |
| クエリキャッシュ制限 | 1048576 |
| クエリ キャッシュの最小解像度単位 | 4096 |
| クエリキャッシュサイズ | 1048576 |
| クエリキャッシュタイプ | オフ |
| query_cache_wlock_invalidate | オフ |
+------------------------------+---------+

have_query_cacheクエリ キャッシュがサポートされているかどうか。

query_cache_limit選択ステートメントの結果セットのサイズが querycachelimit の値を超える場合、結果セットはクエリ キャッシュに追加されません。

query_cache_min_res_unitクエリ キャッシュはブロック単位のメモリ空間に適用され、適用される各ブロックのサイズは設定値です。 4K は非常に適切な値なので、変更する必要はありません。

query_cache_sizeクエリ キャッシュのサイズ。

query_cache_typeクエリ キャッシュ タイプ。値は 0 (OFF)、1 (ON)、2 (DEMOND) です。 OFF はクエリ キャッシュが無効であることを意味します。 ON は、SELECT ステートメントに sql_no_cache オプションが含まれていない限り、クエリは常に最初にクエリ キャッシュを検索することを意味します。 DEMOND は、SELECT ステートメントに sql_cache オプションが含まれていない限り、キャッシュが適用されないことを意味します。

query_cache_wlock_invalidate このパラメータは、行レベルの排他ロックとクエリ キャッシュの関係を設定するために使用されます。デフォルト値は 0 (OFF) です。これは、行レベルの排他ロックが適用されている間、テーブルのすべてのクエリ キャッシュが有効なままであることを意味します。 1 (ON) に設定すると、行レベルの排他ロックが付与されている間、テーブルのすべてのクエリ キャッシュが無効になります。

クエリキャッシュヒット率を表示する

mysql> 'Qcache%' のようなステータスを表示します。
+-------------------------+---------+
| 変数名 | 値 |
+-------------------------+---------+
| Qcache_free_blocks | 1 |
| Qcache_free_memory | 1031360 |
| Qcache_hits | 0 |
| Qcache_inserts | 0 |
| Qcache_lowmem_prunes | 0 |
| Qcache_not_cached | 0 |
| Qcache_queries_in_cache | 0 |
| Qcache_total_blocks | 1 |
+-------------------------+---------+

現在のキャッシュステータス情報を表示します。

Qキャッシュ空きブロック

クエリ キャッシュ内の繰り返し状態にあるメモリ ブロックの数 (フラグメントの数) を示します。 Qcache_free_blocks の値が大きい場合、クエリ キャッシュにフラグメントが多く存在し、クエリ結果セットが小さいことを示しています。この場合、query_cache_min_res_unit の値を減らすことができます。フラッシュ クエリ キャッシュを使用すると、キャッシュ内の複数のフラグメントが整理され、より大きな空きブロックが取得されます。キャッシュ断片化率 = Qcache_free_blocks/ Qcache_total_blocks * 100%

Qキャッシュ空きメモリ

現在の MySQL サービス インスタンスのクエリ キャッシュに使用できるメモリの量を示します。

Qキャッシュヒット

クエリ キャッシュが使用された回数を示します。値は順番に増加します。 Qcache_hits が比較的大きい場合は、クエリ キャッシュが非常に頻繁に使用されていることを意味し、クエリ キャッシュを増やす必要があります。

Qcache_挿入

クエリ キャッシュにキャッシュされた SELECT ステートメント結果セットの合計数を示します。

Qcache_lowmen_prunes

クエリ キャッシュがいっぱいでオーバーフローしたために MySQL が削除したクエリ結果の数を示します。この値が大きい場合は、クエリ キャッシュが小さすぎることを示します。

Qキャッシュがキャッシュされていない

クエリキャッシュに入っていない選択の数を示します

Qcache_queryies_in_cache

クエリキャッシュにキャッシュされている選択ステートメントの結果セットの数を示します。

Qキャッシュ合計ブロック数

クエリキャッシュの合計数

キャッシュヒット率の計算方法: クエリキャッシュヒット率 = Qcache_hits / Com_select * 100%

Com_select は、現在の MySQL インスタンスによって実行された select ステートメントの数です。一般的には、Com_select = Qcache_insert + Qcache_not_cached です。 Qcache_not_cached には、頻繁なデータ変更によりクエリ キャッシュの無効化を引き起こす選択ステートメントが含まれているため、ヒット率は一般的に低くなります。無効化の要因を無視すると、クエリ キャッシュ ヒット率 = Qcache_hits / (Qcache_hits + Qcache_inserts) となります。この式を使用して計算されたクエリ キャッシュ ヒット率が比較的高い場合、ほとんどの選択ステートメントがクエリ キャッシュにヒットしていることを意味します。

現在のシステムで実行された選択ステートメントの数を表示するには、次のコマンドを使用します。

mysql> 'Com_select' のようなステータスを表示します。
+---------------+-------+
| 変数名 | 値 |
+---------------+-------+
| Com_select | 1 |
+---------------+-------+

2. 結果セットキャッシュ

結果セット キャッシュは、MySQL クライアントがサーバーに正常に接続した後に作成されるセッション キャッシュです。 MySQL サーバーは、各 MySQL クライアントの結果セット キャッシュを維持します。 MySQL クライアント接続スレッドの接続情報をキャッシュし、MySQL クライアントに返される結果セット情報をキャッシュします。MySQL クライアントがサーバーに SELECT ステートメントを送信すると、MySQL は SELECT ステートメントの実行結果を結果セット キャッシュに一時的に保存します。結果セットのバッファ サイズは、net_buffer_length パラメータ値によって定義されます。

mysql> 'net_buffer_length' のような変数を表示します。
+-------------------+------+
| 変数名 | 値 |
+-------------------+------+
| ネットバッファ長 | 16384 |
+-------------------+------+

結果セットが net_buffer_length で設定された値を超える場合、容量は自動的に拡張されますが、max_allowd_packet のしきい値を超えることはありません。

mysql> 'max_allowed_pa​​cket' のような変数を表示します。
+--------------------+---------+
| 変数名 | 値 |
+--------------------+---------+
| 最大許容パケット | 4194304 |
+--------------------+---------+

3. ソートキャッシュ

MySQL では通常、InnoDB と MyISAM という 2 つのデータ ストレージ エンジンが使用されます。そのため、最適化を行う際には、各エンジンはそれぞれのエンジンに適した最適化手法を使用します。 MySQL と InnoDB のテーブル構造ファイルとデータ ログ ファイルの違いについては、まず私のブログ「MySQL ログ システム」を読んで、これらの基本概念を十分に理解してください。次に、エンジンの最適化方法を読んで、簡単に実行でき、退屈を感じないようにすることができます。

1. 通常のソートキャッシュ

クライアントからサーバーに送信された SQL ステートメントに、デザイン ソート用の order by 句または group by 句が含まれている場合、ソート キャッシュはセッション キャッシュになります。 MySQL は対応するソート アルゴリズムを選択し、共通のソート インデックスに基づいてソートして、ソート速度を向上させます。通常のソート インデックスのサイズは、sort_buffer_size パラメータによって定義されます。ソート速度を上げたい場合は、まず適切なインデックスを追加し、次にソート インデックス キャッシュ sort_buffer_size を増やす必要があります。

mysql> @@global.sort_buffer_size / 1024 を選択します。
+----------------------------------+
| @@global.sort_buffer_size / 1024 |
+----------------------------------+
| 256.0000 |
+----------------------------------+
セット内の 1 行 (0.00 秒)

次に、ソート キャッシュに関連するパラメータを見てみましょう。

mysql> '%sort%' のような変数を表示します。
+--------------------------------+---------------------+
| 変数名 | 値 |
+--------------------------------+---------------------+
| innodb_disable_sort_file_cache | オフ |
| innodb_ft_sort_pll_degree | 2 |
| innodb_sort_buffer_size | 1048576 |
| ソートデータの最大長 | 1024 |
| 最大ソート長 | 1024 |
| myisam_max_sort_file_size | 9223372036853727232 |
| myisam_sort_buffer_size | 8388608 |
| ソートバッファサイズ | 262144 |
+--------------------------------+---------------------+

mysql> '%sort%' のようなステータスを表示します。
+-------------------+------+
| 変数名 | 値 |
+-------------------+------+
| ソートマージパス | 0 |
| ソート範囲 | 0 |
| 行の並べ替え | 0 |
| ソートスキャン | 0 |
+-------------------+------+

ソートデータの最大長

デフォルトのサイズは 1024 バイトです。ソート操作は各列に対して実行されます。列の値の長さが長い場合は、このパラメータを増やすことで MySQL のパフォーマンスを向上させることができます。

最大ソート長

order by または group by を使用すると、列の最初の max_sort_length バイトがソートに使用されます。ソート操作が完了すると、ソート情報がこのセッションのステータスに記録されます。

ソート_マージ_パス

一時ファイルを使用してソート操作が完了した回数。 MySQL がソート操作を実行する場合、最初に通常のソート キャッシュ内でソートを完了しようとします。キャッシュスペースが不十分な場合、MySQL はキャッシュを使用して複数のソートを実行します。そして、それぞれのソート結果を一時ファイルに保存し、最後に一時ファイル内のデータを再度ソートします。 Sort_merge_passes 値は、ファイルがソートされた回数を記録します。ファイルの並べ替えには、ファイルの読み取り、ファイル ハンドルのオープン、そしてファイルのクローズが含まれるためです。そのため、ファイルの読み取りによるシステム消費は比較的大きくなります。通常のソート キャッシュ sort_buffer_size を増やすことで、ソートに一時ファイルを使用する回数を減らすことができ、ソートのパフォーマンスが向上します。

並べ替え範囲

範囲ソートが使用される回数

行の並べ替え

ソートされた行数

ソートスキャン

フルテーブルスキャンによってソートが完了した回数

2. MyISAMソートキャッシュ

alter table ステートメントまたは create index ステートメントを使用して MyISAM テーブルのインデックスを作成したり、load data infile path を使用してデータの一部をインポートしたりすると、これらの操作によってインデックスが再構築されます。インデックスを再構築するときには、インデックス フィールドをソートする必要があります。インデックス再構築の効率を高速化するために、MyISAM はインデックスのソート作業を実装するためのソート キャッシュを提供します。これらのメソッドは、メモリ内でソート作業を完了しようとします。 MyISAM ソート キャッシュのサイズは、myisam_sort_buffer_size によって定義されます。インデックスが再構築されると、キャッシュはすぐに解放されます。

ただし、ソート キャッシュが myisam_sort_buffer_size のしきい値を超えると、一時ファイルでインデックス フィールドのソートを完了する必要があります。外部一時ファイルのサイズは、myisam_max_sort_file_size パラメータによって設定されます。インデックスが再構築されると、一時ファイルはすぐに削除されます。

mysql> @@global.myisam_sort_buffer_size/1024 を選択します。
+---------------------------------------+
| @@global.myisam_sort_buffer_size/1024 |
+---------------------------------------+
| 8192.0000 |
+---------------------------------------+

mysql> @@global.myisam_max_sort_file_size /1024 を選択します。
+------------------------------------------+
| @@global.myisam_max_sort_file_size /1024 |
+------------------------------------------+
|9007199254739967.7734 |
+------------------------------------------+

3. InnoDBソートキャッシュ

MyISAM エンジンと同様に、alter table または create index を実行すると、InnoDB はインデックスのソート用に 3 つの InnoDB ソート バッファを提供します。各キャッシュのサイズは innodb_sort_buffer_size によって定義されます。

mysql> @@global.innodb_sort_buffer_size/1024 を選択します。
+---------------------------------------+
| @@global.innodb_sort_buffer_size/1024 |
+---------------------------------------+
| 1024.0000 |
+---------------------------------------+

4. 接続キャッシュに参加する

結合キャッシュはセッション キャッシュです。2 つのテーブルが接続されているがインデックスが使用できない場合 (これが結合キャッシュを使用する前提です)、MySQL は各テーブルに結合キャッシュを割り当てます。

mysql> @@global.join_buffer_size/1024 を選択します。
+--------------------------------+
| @@global.join_buffer_size/1024 |
+--------------------------------+
| 256.0000 |
+--------------------------------+

join_buffer_size は、上記のように接続バッファのサイズを定義します。デフォルトは 256 です。

5. テーブルキャッシュとテーブル構造定義キャッシュ

MySQL サービスがデータベース内のテーブルにアクセスすると、MySQL は実際にファイルの読み取り操作を実行します。 MySQL データはハードディスク上のファイルに保存されます。これは、一部のメモリベースのデータベースとは異なります。クエリ キャッシュの使用を考慮せずに、select ステートメントを使用してテーブルをクエリする場合、オペレーティング システムは最初にファイルを開いて、ファイルの記述子を生成する必要があります。オペレーティング システムはファイル記述子を MySQL に渡し、MySQL がデータベースに対して CURD 操作を実行できるようにします。ファイルを開いてファイル記述子を生成すると、システム リソースが消費され、アクセスが遅延します。 MySQL は、ファイル記述子を含む開かれたファイルをキャッシュするため、将来そのファイルに再度アクセスするときにファイルを開く必要がなくなり、ファイルの読み取り効率が向上します。

テーブル構造は頻繁に変更されません。テーブルにアクセスすると、MySQL のテーブル キャッシュにテーブルが埋め込まれるだけでなく、次回の使用に備えてテーブル構造がテーブル構造定義キャッシュにも保存されます。

mysql> 'table%' のような変数を表示します。
+----------------------------+-------+
| 変数名 | 値 |
+----------------------------+-------+
| テーブル定義キャッシュ | 1400 |
| テーブルオープンキャッシュ | 2000 |
| テーブルオープンキャッシュインスタンス | 1 |
+----------------------------+-------+

mysql> '%open%' のような変数を表示します。
+----------------------------+----------+
| 変数名 | 値 |
+----------------------------+----------+
| have_openssl | 無効 |
| innodb_open_files | 2000 |
| オープンファイル制限 | 65535 |
| テーブルオープンキャッシュ | 2000 |
| テーブルオープンキャッシュインスタンス | 1 |
+----------------------------+----------+

テーブルオープンキャッシュ

キャッシュできるテーブルとビューの数に制限を設定します

テーブル定義キャッシュ

保存できるfrmテーブル構造の数を設定します

MySQL MyISAM エンジンの場合、テーブル構造には、テーブル構造 frm に加えて、MYI と MYD が含まれます。MyISAM エンジンにアクセスする場合、2 つのファイル (MYI と MYD) を一度に開いて、2 つのファイル記述子を生成する必要があります。

オープンファイル制限

開いているファイルの最大数

innodb_open_files

InnoDB テーブルが独立したテーブルスペース ファイル (ibd) を使用する場合、このパラメータは同時に開くことができるファイルの数を設定します。

以下は、テーブルを開くことに関連するステータス値です。

mysql> 'Open%' のようなステータスを表示します。
+--------------------------+-------+
| 変数名 | 値 |
+--------------------------+-------+
| 開いているファイル | 18 |
| オープンストリーム | 0 |
| テーブル定義を開く | 70 |
| オープンテーブル | 63 |
| 開いたファイル | 125 |
| オープンされたテーブル定義 | 0 |
| オープンしたテーブル | 0 |
+--------------------------+-------+

6. テーブルスキャンバッファ

テーブルスキャンは、シーケンシャルスキャンとランダムスキャンの 2 種類に分けられます。

MyISAM テーブルにインデックスがない場合、クエリ速度は完全なテーブルスキャンとなり、非常に非効率的になります。完全なテーブルスキャンの速度を上げるために、MySQL はシーケンシャルスキャン キャッシュ (読み取りバッファ) を提供します。このとき、MySQL は格納されたデータの格納順序に従ってすべてのデータ ブロックを読み取ります。読み取られた各データ ブロックは、シーケンシャル スキャン キャッシュにキャッシュされます。読み取りバッファがいっぱいになると、データは上位レベルの呼び出し元に返されます。

ランダムスキャン

テーブルにキャッシュがある場合、テーブルをスキャンするときに、まずテーブルのインデックス フィールドがメモリに格納され、ソートされ、次にソートされた順序に従ってハードディスク上でデータが検索されます。

7. MyISAMインデックスキャッシュバッファ

MYI インデックス ファイルの内容をキャッシュすることで、インデックスの読み取り速度とインデックス作成速度を高速化できます。インデックス キャッシュは MyISAM テーブルに対してのみ機能し、すべてのスレッドで共有されます。クエリ ステートメントまたはインデックス更新がインデックスを介してテーブル データにアクセスする場合、MySQL はまず、必要なインデックス情報がインデックス キャッシュにすでに存在するかどうかを確認します。存在する場合、キャッシュ内のインデックスを介して、インデックスに対応する MYD ファイルに直接アクセスできます。そうでない場合は、MYI ファイルが読み込まれ、対応するインデックス データがキャッシュに読み込まれます。インデックス キャッシュは、MyISAM テーブルのアクセス パフォーマンスにおいて重要な役割を果たします。

mysql> 'key%' のような変数を表示します。
+--------------------------+---------+
| 変数名 | 値 |
+--------------------------+---------+
| キーバッファサイズ | 8388608 (8M)| 
| キーキャッシュの有効期間しきい値 | 300 |
| キーキャッシュブロックサイズ | 1024 |
| キーキャッシュ分割制限 | 100 |
+--------------------------+---------+

キーバッファサイズ

インデックス キャッシュのサイズを設定します。デフォルトは 8M です。改善を推奨します。

キーキャッシュブロックサイズ

各インデックスキャッシュのブロックサイズを指定します。4K、つまり4096に設定することをお勧めします。

キーキャッシュ分割制限

キャッシュを効果的に使用します。デフォルトでは、MySQL キャッシュはウォーム領域とホット領域の 2 つのインデックス キャッシュ領域に分割されます。 key_cache_division_limit パラメータは、インデックス キャッシュをパーセンテージの形式で複数の領域に分割します。デフォルト値が 100 の場合、インデックス キャッシュにはウォーム ゾーンのみがあり、インデックス キャッシュ内のインデックスを削除する LRU アルゴリズムが有効になります。

キーキャッシュの年齢しきい値

ウォーム ゾーンとホット ゾーンのインデックスが昇格または降格されるタイミングを制御します。値が 100 未満の場合、ホット スポットが存在します。移動アルゴリズムは、LRU アルゴリズムとほぼ同じです。

現在の MySQL サービス インスタンスのインデックス読み取りとインデックス書き込みのステータス値を表示します。

mysql> 'Key%' のようなステータスを表示します。
+------------------------+-------+
| 変数名 | 値 |
+------------------------+-------+
| キーブロックがフラッシュされていません | 0 |
| 未使用のキーブロック | 6698 |
| 使用されたキーブロック | 0 |
| キー読み取り要求 | 0 |
| キー読み取り | 0 |
| キー書き込み要求 | 0 |
| キー書き込み | 0 |
+------------------------+-------+

8. ログキャッシュ

ログキャッシュはバイナリログキャッシュとInnoDB REDOログキャッシュに分かれています。

1. バイナリログキャッシュ

mysql> '%binlog%cache%' のような変数を表示します。
+----------------------------+----------------------+
| 変数名 | 値 |
+----------------------------+----------------------+
| binlog_cache_size | 32768 |
| binlog_stmt_cache_size | 32768 |
| 最大バイナリログキャッシュサイズ | 18446744073709547520 |
| 最大 binlog_stmt キャッシュ サイズ | 18446744073709547520 |
+----------------------------+----------------------+

mysql> '%binlog%cache%' のようなステータスを表示します。
+----------------------------+-------+
| 変数名 | 値 |
+----------------------------+-------+
| Binlog_cache_disk_use | 0 |
| Binlog_cache_use | 0 |
| Binlog_stmt_cache_disk_use | 0 |
| Binlog_stmt_cache_use | 0 |
+----------------------------+-------+

Mysql はデータを作成または更新すると、バイナリ ログを記録します。ただし、頻繁な I/O 操作は MySQL のパフォーマンスに大きな影響を与えます。そのため、MySQL はバイナリ ログ キャッシュ binlog_cache_size をオープンしました。まず、操作がバイナリ ログに書き込まれ、操作が成功するとバイナリ ログがハード ディスクに書き込まれます。

2. InnoDB REDOログキャッシュ

トランザクションがコミットされる前に、生成された redo ログが InnoDB redo ログ キャッシュに書き込まれます。次に、InnoDB は [機会を選択して] ポーリング戦略を実行し、キャッシュ内の redo ログ ファイルを ib_logfile0 および ib_logfile1 redo ログに書き込みます。

mysql> 'innodb_log_buffer_size' のような変数を表示します。
+------------------------+----------+
| 変数名 | 値 |
+------------------------+----------+
| innodb_log_buffer_size | 8388608 |
+------------------------+----------+

InnoDB 再実行ログ キャッシュは、トランザクション中に生成された再実行ログが、トランザクションがコミットされる前に InnoDB ログ キャッシュに保存され、再実行ログ ファイルには書き込まれないことを保証します。書き込みのタイミングは、innodb_flush_log_at_trx_commit パラメータによって制御されます。

mysql> 'innodb_flush_log%' のような変数を表示します。
+--------------------------------+-------+
| 変数名 | 値 |
+--------------------------------+-------+
| innodb_flush_log_at_timeout | 1 |
| innodb_flush_log_at_trx_commit | 1 |
+--------------------------------+-------+

0: キャッシュ内のREDOログファイルが1秒ごとにディスクキャッシュに書き込まれると同時にディスクにも更新されます。

1: トランザクションがコミットされるたびに、キャッシュ内の REDO ログが REDO ログ ファイルに書き込まれ、同時にハードディスクに書き込まれます。これがデフォルトの動作です。

2: トランザクションがコミットされると、キャッシュに書き込まれますが、ファイルシステムからハードディスクへの同期操作はトリガーされません。また、ハードディスクは 1 秒に 1 回同期されます。

9. 先読みメカニズム

事前読み取りメカニズムは、主に、以前の MySQL 最適化で説明した原則を使用します: 1. キャッシュ最適化。つまり、地域特性、空間的局所性、時間的局所性ですが、ここでは詳しく説明しません。

1. InnoDBの先読みメカニズム

InnoDB は先読みメカニズムを使用して、インデックスを含む「将来アクセスされるデータ」を先読みキャッシュにロードし、データの読み取りパフォーマンスを向上させます。 InnoDB は、線形先読みとランダム先読みの 2 つの方法をサポートしています。

データ ブロック (ページ) は、InnoDB ハードディスク管理の最小単位です。ゾーンは 64 個の連続したデータ ブロックで構成されます。シーケンシャル先読みの場合、InnoDB は、データが配置されているデータ ブロックを InnoDB キャッシュ プールに配置することを優先します。これらのデータ ブロックの後続のブロックはすぐにアクセスされると予測できるため、これらのデータ ブロックと先行するデータ ブロックはメモリに配置されます。 innodb_read_ahead_threshold パラメータに基づいて、先読みするデータ ブロックの数を設定します。

mysql> 'innodb_read_ahead%' のような変数を表示します。
+-----------------------------+-------+
| 変数名 | 値 |
+-----------------------------+-------+
| innodb_read_ahead_threshold | 56 |
+-----------------------------+-------+

2. インデックスキャッシュのプリロード

データベース管理者は、MySQL コマンド load index into cache を使用して、MyISAM テーブル インデックスを事前ロードできます。

10. MyISAMテーブルの遅延挿入

mysql> '%delayed%' のような変数を表示します。
+----------------------------+-------+
| 変数名 | 値 |
+----------------------------+-------+
| 遅延挿入制限 | 100 |
| 遅延挿入タイムアウト | 300 |
| 遅延キューサイズ | 1000 |
| 最大遅延スレッド数 | 20 |
| 最大挿入遅延スレッド数 | 20 |
+----------------------------+-------+

この遅延挿入機能を見て、プロジェクト内の似たような機能を思い出し、それが私自身のアイデアのきっかけとなりました。

使用方法は次のとおりです: insert delyed into table values(*);

挿入制限の遅延

デフォルト値は 100 です。MySQL テーブルに 100 行が挿入された後、テーブル内で実行を待機している SELECT ステートメントがあるかどうかを確認します。ある場合は、INSERT ステートメントの実行を一時停止します。

遅延挿入タイムアウト

タイムアウト範囲内で遅延キューにデータがない場合、遅延挿入スレッドはシャットダウンされます。

遅延キューサイズ

遅延挿入のキューの長さ。これを超えると、十分なスペースができるまでブロックされます。

最大遅延スレッド数

遅延挿入のスレッド数。

MyISAM テーブルへのバッチ遅延挿入

テーブルに値(1)、値(2)、値(n)を挿入するのと同様です。 MyISAM はバッチ挿入を実行します。挿入されたデータをまずキャッシュに格納します。キャッシュがいっぱいになるかコミットされると、MySQL はキャッシュをすぐにディスクに書き込みます。バッチ挿入を使用すると、MySQL クライアントとサーバー間の接続構文分析やその他のコストが大幅に削減され、個々の挿入ステートメントを個別に実行するよりも効率が大幅に向上します。

mysql> @@global.bulk_insert_buffer_size/(1024*1024) を選択します。
+------------------------------------------------+
| @@global.bulk_insert_buffer_size/(1024*1024) |
+------------------------------------------------+
| 8.0000 |
+------------------------------------------------+

デフォルトのバッチ挿入サイズは 8M です。ビジネス上の必要に応じて、この値を大きく設定してバッチ挿入のパフォーマンスを向上させることができます。

MyISAM テーブルのインデックスの遅延更新

インデックスを使用すると、データの取得が高速化されますが、更新の場合は、レコードを変更するだけでなく、インデックスも変更する必要がある場合があります。そのため、インデックスを使用すると、データの更新操作が遅くなります。MySQL delay_key_write パラメータを 1 (ON) に設定すると、この欠点を補うことができます。更新操作を有効にすると、データが変更されると、まずハードディスクにデータ更新が送信され、インデックス キャッシュ内でインデックス更新がすべて完了します。テーブルを閉じるときに、ハードディスクに一緒に更新することで、インデックスの更新が速くなります。 MyISAM のみ有効です。

mysql> 'delay_key_write' のような変数を表示します。
+-----------------+-------+
| 変数名 | 値 |
+-----------------+-------+
| delay_key_write | オン |
+-----------------+-------+

InnoDB 遅延更新

非クラスター化インデックスの更新操作は通常、ランダム I/O を引き起こし、InoDB のパフォーマンスを低下させます。非クラスター化インデックスのデータを更新 (挿入、削除、更新 = 挿入 + 削除) する場合、まず非クラスター化インデックス ページが InnoDB バッファ プールにあるかどうかを確認します。ある場合は、直接更新されます。そうでない場合は、まず「情報の変更」が更新バッファに記録されます。

このブログには多くのコンテンツが含まれているため、後で確認できるように要約します。まず、MySQL 全体を最適化するための全体的なフレームワークを用意し、段階的に進歩させる必要があります。これらのパラメータを覚えておく必要はありません。必要な場合は、ブログまたは Baidu で調べてください。 Taoを理解し、テクニックを知っていれば、最適化プロセスを完了できます。退屈な原理を暗記するよりも原理を知るほうがずっと簡単です。 MySQL の最適化に興味のあるブロガーは、私のブログをフォローして、今後の共有内容を確認することができます。

以下もご興味があるかもしれません:
  • MySQL 最適化: キャッシュ最適化
  • MySQLクエリキャッシュをクリアする方法
  • MySQLクエリキャッシュの説明
  • Memcache を使用して MySQL データベース操作をキャッシュする原理とキャッシュ プロセスの簡単な分析
  • MySQL メモリの使用に関する簡単な分析 (グローバル キャッシュ + スレッド キャッシュ)
  • MySQL キャッシュの起動方法とパラメータの詳細 (query_cache_size)
  • MySQL キャッシュのクエリおよびクリアコマンドの詳細な説明
  • mysql クエリ キャッシュの設定
  • MySQL DBA チュートリアル: MySQL パフォーマンス最適化キャッシュパラメータ最適化

<<:  要素のフォームコンポーネントに関する注意事項

>>:  Ubuntu で XFS ファイルシステム用の LVM を作成する方法

推薦する

Nginx のアンチホットリンクを設定する方法

実験環境• 最小限のインストール済みの CentOS 7.3 仮想マシン• 構成: 1 コア/512...

Ubuntu 18.04にMySQL 5.7をインストールする

この記事は MySQL 公式サイトを参考にしてまとめたものであり、遭遇したいくつかの問題も記録されて...

イメージのアップロードとダウンロードに docker をプロキシするためのプライベート ライブラリとして nexus を使用する

1. Nexusの設定1. Dockerプロキシを作成する外部ネットワーク ウェアハウスからローカル...

VMware 仮想マシンのインストール Linux システムのグラフィック チュートリアル

この記事では、LinuxシステムのVMwareインストールの具体的な手順を参考までに紹介します。具体...

新しいユーザーを作成し、MySQLに権限を付与する最も簡単な方法

ユーザーを作成します: 'oukele' によって識別されるユーザー 'ou...

JSに関する7つの面接の質問、あなたはいくつ正しく答えられますか

序文JavaScript では、これは関数呼び出しコンテキストです。この動作が非常に複雑であるからこ...

jsを使用して写真をアップロードする機能を実現する

フロントエンドで画像をアップロードする原理は、入力 type="file" タグ...

純粋な CSS を使用して 3D 回転効果を実装するサンプル コード

3D効果を実現するには、主にCSSのpreserve-3dプロパティとperspectiveプロパテ...

Vueスロットの実装原理についての簡単な説明

目次1. サンプルコード2. 現象を通して本質を見抜く3. 実施原則4. 親コンポーネントのコンパイ...

4種類のMySQL接続とマルチテーブルクエリの詳細な説明

目次MySQL 内部結合、左結合、右結合、外部結合、複数テーブルクエリビルド環境: 1. 内なる慈恩...

フォント宝庫 50 種類の素晴らしい無料英語フォントリソース パート 2

デザイナーは独自のフォント ライブラリを持っているため、プロジェクトの設計時にすぐに使用できます。今...

Linuxで現在のスクリプトの実際のパスを取得する方法

1. 現在のスクリプトの実際のパスを取得します。 #!/bin/bash if [[ $0 =~ ^...

Vue3スタイルのCSS変数注入の実装

目次まとめ基本的な例モチベーションデザインの詳細コンパイルの詳細採用戦略練習するヒント適切なプロパテ...

CSS3 Flex エラスティックレイアウトのサンプルコードの詳細な説明

1. 基本概念 //任意のコンテナを Flex レイアウトとして指定できます。 。箱{ ディスプレイ...

MySQL テーブル作成外部キー エラーの解決方法

データベーステーブルA: テーブル task_desc_tab を作成します ( id INT(11...