ハードディスクメンテナンス ブログ

投稿記事数7,500以上!PC,カメラ,オーディオ,ラジオ,航空,旧ゲームなど

クエリに対して複数コアを使いこなさない問題(MySQL)

   


3コアのCPUに換装したDBサーバーであるが、重いクエリを発行した場合、複数コアを有効に使っていないことに気付く。

まぁ、これは換装前(2コア)の時点で、既に分かっていたことであるが。

# 今回は余っていたCPUを転用しただけで、費用は掛かっていないのだ。

実際にモニターしてみると…

3コア

グラフの全範囲でCPU占有率は高いものの、100%に達しているのは3つあるうちの1コアだけである。

しかも、ほとんどが橙色(CPU1)であり、たまに赤色(CPU2)と緑色(CPU3)が「登板」するものの、それらはごく短時間。

CPU1がMAX(100%)まで使われている間、CPU2とCPU3が40%以下で休んでいるなら、CPU2とCPU3もMAXまで使い、処理時間を短くしろ、と、普通は考えるだろう。

同じハード構成で、別のパターン。

3コア

CPUの入れ替わりは先の場合に比べ頻繁になってはいるが、100%に達しているのは1つだけだ。

ッたく、他は何をやってるんだ!

これなら3コアを雇用する意味はない!

解雇(クビ)だ!クビ!

と、実世界ではなりそう(マジレスするとなってるw)が、これは、1つのクエリを複数のコアで処理することができないため。

また、本件のMySQLのバージョンは5.1.73であり、古いことも影響している。

まぁ、最近はシングルコアを探すのが難しく、最安のCeleronでもDualコアなので、あまり神経質になることもなかろう。

複数クエリや複数使用となってくると、複数コアのメリットが生きてくる。

今回は業務(つまり社内)用途であり、同時利用者数がそれほど多くないので、複数コアを上手く生かせないが、これが一般公開WEBサービス等で、利用者が非常に多い場合は、複数コアを生かせるだろう。

スポンサーリンク

サーバーの場合、ディスクやメモリーは分かりやすい(簡単)であるが、CPUの場合は意外と複雑なのだ。

クライアント端末の場合は、CPU不可が高い原因は比較的簡単に掴めるし、用途が分かればCPU能力が必要かは判断できる(エンコードであればCPU等)が、サーバーの場合は用途だけでなく、その細部を探らなければならない。

いずれにしても今は安いので、それなりの用途(大規模ではない)であれば、CPUもメモリーもディスクもそれなりのもので十分。

それでも遅いなら、DBの設計やSQL文、indexが有効に使用されているか等を見直すことだ。

あとは、工夫。

最終結果の表示が遅いなら、最終結果をDBに格納しておき、それを出せば軽くなる。

少しでも速く ━

開発をしているとそういう気になってしまい、CPUを変えたら?と思うが、そういう場合、替えても大して速くならない(泣)

その後、基本に戻るのだが、そのような考えが「定期的に」出てくるので困ったものだ(笑)

実践ハイパフォーマンスMySQL 第3版
Baron Schwartz Peter Zaitsev Vadim Tkachenko
オライリージャパン
売り上げランキング: 21,426


sha-bc@336×280

アマゾン(タイムセール)




sha-bc@336×280

アマゾン(タイムセール)


  関連記事

no image
RedHatLinux9のインストール

RedHatLinux9のインストールをしました。 Linuxを入れるのは、Re …

アカ(Ubuntu 14.04)_内部エラー
内部エラーが発生しました(Ubuntu 14.04)

メモリー不足か熱杉流セーか不明だが、CF-R6上で動いているUbuntuでエラー …

no image
[解決]ローカル内の他の端末からMySQLに接続できない件[my.cnf,bind-address]

DebianにMySQLを入れてDBサーバーとし、ローカル環境に置く。 試験サー …

Ubuntu
Ubuntu(14.04 LTS)の電源の統計一覧とバッテリーの劣化 [CF-VZSU49,CF-R6,CF-R7,CF-R8]

Linuxは標準で、ここまで細かい電源の情報を得ることができる。 Ubuntuな …

霜
冷杉流冷蔵庫 vs 灼熱CF-R6 – 冷却と発熱の仁義ナキ戦い、キミはこの衝撃に耐えられるかッ!!

冷蔵庫のハナシをこのブログで書くとは思わなかったが… 自宅には冷蔵庫 …

no image
Debianのミラーの片方に不良セクタが発生(Current Pending Sector Count)

Debianのミラーの片方に不良セクタが発生した(代替処理待ちのセクタ)。 Cu …

no image
PowerEdgeT105のCPU換装(2コアから3コアに)

DELLのサーバーであるPowerEdgeT105のCPUを ①Athlon64 …

no image
mysqlimport –helpの内容 csvファイルの内容をデータベースにインポートする

mysqlimport –help の内容を以下に付しておく。 試験 …

idを詰める(連番を振り直す)方法
[MySQL] idを詰める(連番を振り直す)方法

数分毎に定期的にログを取得するようなプログラムを書き、DBに格納し始める。 だが …

no image
業務サーバーのCPU負荷が100%

業務サーバー(Linux)のCPU負荷が100%に。 スポンサーリンク MySQ …