MySQL には以前、クエリ キャッシュ (Query Cache) がありました。8.0 以降では、このクエリ キャッシュは使用されなくなりました。では、これを廃止する理由は何でしょうか?この記事ではそれについて紹介します。 MySQL クエリ キャッシュは、クエリ結果のキャッシュです。 SEL で始まるクエリをハッシュ テーブルと比較し、一致する場合は前のクエリの結果を返します。一致させる場合、クエリはバイトごとに一致させる必要があります。たとえば、SELECT * FROM t1; は select * from t1; と同じではありません。また、不確実なクエリ結果の一部はキャッシュできず、テーブルを変更すると、これらのテーブルのすべてのキャッシュが無効になります。したがって、クエリ キャッシュの最適なシナリオは読み取り専用であり、特に数百万行を調べて数行のみを返す必要がある複雑なクエリではこれが当てはまります。クエリがこのような特性を満たしている場合、クエリ キャッシュを有効にするとクエリのパフォーマンスが向上します。 テクノロジーが進歩し、時間が経つにつれて、MySQL エンジニアリング チームは、キャッシュを有効にしてもメリットがあまりないことに気付きました。 まず、クエリ キャッシュの効果はキャッシュ ヒット率に依存します。キャッシュにヒットしたクエリのみが改善できるため、そのパフォーマンスを予測することはできません。 2 番目に、クエリ キャッシュのもう 1 つの大きな問題は、単一のミューテックスによって保護されていることです。多数のコアを持つサーバーでは、クエリの数が多くなると、ミューテックスの競合が多発する可能性があります。 ベンチマークの結果、ほとんどのワークロードはクエリキャッシュを無効にすることで最適に処理されることがわかりました(5.6のデフォルト):query_cache_type = 0 クエリ キャッシュが役立つと思われる場合は、それに応じてテストしてください。
MySQL 8.0 がクエリ キャッシュをキャンセルするもう 1 つの理由は、調査により、キャッシュがクライアントに近いほどメリットが大きくなることが示されているためです。この調査の詳細については、https://proxysql.com/blog/scaling-with-proxysql-query-cache/ を参照してください。 以下の画像は上記の URL からのものです。 さらに、MySQL 8.0 ではパフォーマンス介入のための新しいツールが追加されました。たとえば、クエリ書き換えプラグインを使用して、アプリケーションを変更せずにオプティマイザヒント文を挿入できるようになりました。あるいは、中間キャッシュとして機能できる ProxySQL などのサードパーティ ツールもあります。 上記の理由により、MySQL 8.0 ではクエリ キャッシュがサポートされなくなりました。5.7 から 8.0 にアップグレードする場合は、クエリ リライトまたはその他のキャッシュの使用を検討してください。 全文は以上です。 以上がMySQLがQuery Cacheをキャンセルした理由の詳細です。MySQL Query Cacheの詳細については、123WORDPRESS.COMの他の関連記事にも注目してください。 以下もご興味があるかもしれません:
|
>>: Web インタビュー Vue カスタム コンポーネントと呼び出しメソッド
コマンド: mysqlhotcopyこのコマンドは、ファイルをコピーする前にテーブルをロックし、不完...
序文Linux システムをインストールした後の最も一般的なタスクは、ネットワーク構成です。もちろん、...
目次1. Vスロットの紹介2. 匿名スロット3. 名前付きスロット4. スコープ付きスロット5. 動...
序文この実験では、デバッグ用に2つの仮想マシン(CentOs6とRed Hat 6)を準備します。 ...
1. rzをサーバーにアップロードして解凍する rz [root@mini2 アップロード]# ta...
Docker でシェル コマンドを実行するには、コマンドの前に sh -c を追加する必要があります...
1. MySQL 自己接続MySQL では、情報を照会するときに自分自身に接続 (自己接続) する必...
何人かのブロガーが私の記事を評価してくれたのは嬉しいです。マークと知り合ってからは、私は彼をフォロー...
メソッドが定義されているクラスに応じて、現在のクラスへの静的参照を取得するには、self:: または...
目次1. 遭遇した問題2. アイデア3. コード1. 遭遇した問題私たちは皆、mysqldump を...
目次0x0 はじめに0x1 RBAC 実装0x2 クレームベースの承認0x3 統合 CASL 0x4...
1. プロジェクト構造 2.Tomcat.javaを呼び出す パッケージ com.calltomca...
html <!DOCTYPE html> <html lang="ja&...
<br />外交部などの中央政府機関、各レベルの地方政府、その他の国家機関や部門が率先し...
1. 重複行を見つける blog_user_relation a から * を選択 WHERE (...