MySQL のメモリ使用量と CPU 使用率が高い場合のテストと解決策

MySQL のメモリ使用量と CPU 使用率が高い場合のテストと解決策

変更後:

innodb_buffer_pool_size=576M ->256M InnoDBエンジンバッファはメモリの大部分を占めるので、まずはそれを削減する必要があります。
query_cache_size=100M ->16M クエリ キャッシュ
tmp_table_size=102M ->64M 一時テーブルサイズ
キーバッファサイズ = 256m -> 32M

mysql サービスを再起動すると、仮想メモリが 200 未満に低下しました。

また、MySQL インストール ディレクトリには、my-huge.ini、my-large.ini、my-medium.ini などのファイルがいくつかあります。これらはメモリ サイズに基づいた推奨構成であり、初心者がセットアップ時に参照することもできます。
2G メモリ MYSQL データベース サーバー my.ini 最適化 (my.ini)
2G メモリ、ステーション数が少ない、高品質設定、テスト機能:
table_cache=1024 物理メモリが大きいほど、設定が大きくなります。デフォルトは2402ですが、512~1024に調整するのが最適です。
innodb_additional_mem_pool_size=8M デフォルトは2M
innodb_flush_log_at_trx_commit=0 innodb_log_buffer_size キューが一杯になるまで待ってから均一に保存します。デフォルト値は 1 です。
innodb_log_buffer_size=4M デフォルトは1M
innodb_thread_concurrency=8 サーバーのCPU数を設定します。デフォルトは8です。
key_buffer_size=256M デフォルトは218ですが、128に調整するのが最適です。
tmp_table_size=64M デフォルトは16M、最大値は64~256に調整してください
read_buffer_size=4M デフォルトは64K
read_rnd_buffer_size=16M デフォルトは256K
sort_buffer_size=32M デフォルトは256K
max_connections=1024 デフォルトは1210

テスト1:
table_cache=512 または 1024
innodb_additional_mem_pool_size=2M
innodb_flush_log_at_trx_commit=0
innodb_log_buffer_size=1M
innodb_thread_concurrency=8 サーバーのCPU数を設定します。デフォルトは8です。
キーバッファサイズ=128M
tmp_table_size=128M
read_buffer_size=64K または 128K
読み取りバッファサイズ=256K
ソートバッファサイズ=512K
最大接続数=1024

テスト2:
table_cache=512 または 1024
innodb_additional_mem_pool_size=8M
innodb_flush_log_at_trx_commit=0
innodb_log_buffer_size=4M
innodb_thread_concurrency=8
キーバッファサイズ=128M
tmp_table_size=128M
読み取りバッファサイズ=4M
読み取りバッファサイズ=16M
ソートバッファサイズ=32M
最大接続数=1024

一般的に:
テーブルキャッシュ=512
innodb_additional_mem_pool_size=8M
innodb_flush_log_at_trx_commit=0
innodb_log_buffer_size=4M
innodb_thread_concurrency=8
キーバッファサイズ=128M
tmp_table_size=128M
読み取りバッファサイズ=4M
読み取りバッファサイズ=16M
ソートバッファサイズ=32M
最大接続数=1024

テスト後、特別な状況がない場合は、デフォルトを使用するのが最適です。
2Gメモリ、複数ステーション用、ストレス耐性設定、最適:
table_cache=1024 物理メモリが大きいほど、設定が大きくなります。デフォルトは2402ですが、512~1024に調整するのが最適です。
innodb_additional_mem_pool_size=4M デフォルトは2M
innodb_flush_log_at_trx_commit=1
(0 に設定すると、innodb_log_buffer_size キューがいっぱいになるまで待ってから均一に保存されます。デフォルト値は 1 です)
innodb_log_buffer_size=2M デフォルトは1M
innodb_thread_concurrency=8 サーバーの CPU の数に設定します。デフォルト値は通常 8 です。
key_buffer_size=256M デフォルトは218ですが、128に調整するのが最適です。
tmp_table_size=64M デフォルトは16M、最大値は64~256に調整してください
read_buffer_size=4M デフォルトは64K
read_rnd_buffer_size=16M デフォルトは256K
sort_buffer_size=32M デフォルトは256K
max_connections=1024 デフォルトは1210
thread_cache_size=120 デフォルトは60
クエリキャッシュサイズ=64M

MySQL データベースのパフォーマンスを最適化する 10 個のパラメータ
(1)最大接続数:
許可される同時クライアントの数。この値を増やすと、mysqld に必要なファイル記述子の数が増えます。この数を増やす必要があります。そうしないと、接続エラーが多すぎることがよくあります。 デフォルト値は 100 ですが、1024 に変更しました。
(2)レコードバッファ:
順次スキャンを実行する各スレッドは、スキャンするテーブルごとにこのサイズのバッファを割り当てます。連続スキャンを頻繁に行う場合は、この値を増やすことをお勧めします。デフォルト値は131072(128k)ですが、16773120(16m)に変更しました。
(3)キーバッファサイズ:
インデックス ブロックはバッファリングされ、すべてのスレッドで共有されます。 key_buffer_size はインデックス ブロックに使用されるバッファー サイズです。インデックスの処理 (すべての読み取りと複数の書き込み) を改善するには、このサイズを可能な限り大きくします。大きすぎると、システムがページングを開始し、速度が大幅に低下します。デフォルト値は 8388600 (8M) ですが、私の MySQL ホストには 2GB のメモリがあるため、402649088 (400MB) に変更しました。
4) バックログ:
mysql に許可される接続の数。これは、メインの MySQL スレッドが短時間に多数の接続要求を受け取り、その後メイン スレッドが接続を確認して新しいスレッドを開始するまでに少し時間がかかる (短い時間ではありますが) 場合に機能します。
back_log 値は、MySQL が一時的に新しいリクエストへの応答を停止するまでにスタックできるリクエストの数を示します。短期間に多数の接続が予想される場合にのみ、この値を増やす必要があります。つまり、この値は着信 TCP/IP 接続のリスニング キューのサイズを設定します。オペレーティング システムには、このキュー サイズに対する独自の制限があります。 back_log をオペレーティング システムの制限よりも高く設定しても効果はありません。
ホスト プロセス リストを観察し、接続を待機している 264084 | unauthenticated user | xxx.xxx.xxx.xxx | null | connect | null | login | null プロセスが多数ある場合は、back_log の値を増やす必要があります。デフォルト値は 50 ですが、500 に変更しました。
(5)インタラクティブタイムアウト:
サーバーが対話型接続を閉じる前にアクションを待機する秒数。対話型クライアントは、mysql_real_connect() の client_interactive オプションを使用するクライアントとして定義されます。 デフォルト値は 28800 ですが、7200 に変更しました。
(6)ソートバッファ:
ソートを実行する必要がある各スレッドには、このサイズのバッファが割り当てられます。この値を増やすと、順序付けまたはグループ化操作が高速化されます。デフォルト値は 2097144 (2m) ですが、16777208 (16m) に変更しました。
(7) テーブルキャッシュ:
すべてのスレッドの開いているテーブルの数。この値を増やすと、mysqld に必要なファイル記述子の数が増える可能性があります。 mysql では、一意に開かれたテーブルごとに 2 つのファイル記述子が必要です。デフォルト値は 64 ですが、512 に変更しました。
(8) スレッドキャッシュサイズ:
そこに保存され再利用できるスレッドの数。その場合、新しいスレッドはキャッシュから取得され、切断時にスペースがあれば、クライアントのスレッドがキャッシュに配置されます。新しいスレッドが多数ある場合は、この変数値を増やすとパフォーマンスが向上します。 connections と threads_created 状態変数を比較すると、この変数の役割がわかります。 80に設定しました。
(9) mysql検索機能 mysqlを使用して大文字と小文字を区別せずに検索し、中国語で検索します。mysqldを起動するときに--default-character-set=gb2312を指定するだけです。
(10) 待機タイムアウト:
サーバーが接続を閉じる前にアクションを待機する秒数。 デフォルト値は 28800 ですが、7200 に変更しました。

注: パラメータは、/etc/my.cnf ファイルを変更して mysql を再起動することで調整できます。これは比較的慎重な作業であり、上記の結果はあくまでも私の意見です。自分のホストのハードウェア条件(特にメモリサイズ)に基づいて、さらに変更を加えることができます。

以下もご興味があるかもしれません:
  • MySQL InnoDB ストレージエンジンのメモリ管理の詳細な説明
  • MySQL 8.0 のメモリ消費の詳細な分析
  • MySQL メモリテーブルと一時テーブルの使用方法の詳細な説明
  • MySQL OOM (メモリオーバーフロー) の解決策
  • MySQLのメモリ使用量を表示する方法の詳細な説明
  • MySQLの一般的なメモリ不足による起動失敗に対する完璧な解決策
  • MySQL 5.6 の起動時にメモリ使用量が高くなる問題の解決方法
  • MySQL本番データベースの異常なメモリ増加のトラブルシューティングのプロセスを共有する

<<:  Vue3 を使用してアップロード コンポーネントを実装するためのサンプル コード

>>:  Kubernetes の応用分野の概要

推薦する

MySQL 8.0ドライバとAlibaba Druidバージョン間の互換性の問題を解決

この記事では主に、MySQL 8.0 ドライバーと Alibaba Druid バージョン間の互換性...

Ubuntu 20.04 LTSの詳細なインストール履歴

この記事では、USB ブート ディスクの作成とシステムのインストールについて説明します。システム構成...

Vueはマーキースタイルのテキストの水平スクロールを実装します

この記事では、マーキースタイルのテキストの水平スクロールを実現するためのVueの具体的なコードを参考...

Idea で Tomcat のソースコードデバッグを開始し、デバッグのために Tomcat に入る方法

idea 開発ツールを使用してコードをデバッグする場合、Java Web プロジェクトで、Web コ...

カスタムスクロールバー効果を実現するJavaScript

実際のプロジェクトでは、上下のスクロール バーと左右のスクロール バーは DIV 内にないため、右の...

CenOS6.7 mysql 8.0.22 のインストールと設定方法のグラフィックチュートリアル

CenOS6.7 は MySQL8.0.22 (推奨コレクション) をインストールします1. MyS...

mysql 5.7.20 win64 のインストールと設定方法

mysql-5.7.20-winx64.zipインストール手順のないインストール パッケージ: ht...

Linux プロセスの CPU 使用率が 700% に達し、終了できない場合の解決策

目次1. 問題の発見2. プロセスの詳細情報を表示する3. 解決策4. 大法を再開する1. 問題の発...

非常に詳細な MySQL8.0.22 のインストールと設定のチュートリアル

みなさんこんにちは。今日は、MySQL 8.0.22 のインストールと構成について学習します。注意深...

MySQL 8.0.11 MSI バージョンのインストールと構成のグラフィック チュートリアル

この記事では、MySQL 8.0.11 MSIバージョンのインストールと設定のチュートリアルを参考ま...

vue3.0+echarts は 3 次元の縦棒グラフを実現します

序文: Vue3.0はechartsの3次元縦棒グラフを実装します結果: 実装手順: 1. echa...

CSS で background-color を使用して背景画像にマスク効果を追加する 2 つの方法

div で background-color と background-image を同時に設定する...

MySQLサービスの自動停止の解決策

この記事では主に、MySQL サービスの自動停止の解決策を紹介し、参考と学習のために共有します。一緒...

ローカル Docker に Postgres 12 + pgadmin をインストールする方法 (Apple M1 をサポート)

目次導入Intel CPUをサポートApple M1のサポートテスト導入このプロジェクトでは最近、P...