KondemandプロセスはCPUの大部分を消費します。

KondemandプロセスはCPUの大部分を消費します。

出力は次のとおりですtop

  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
 3551 mysql     20   0 10.0g  84m 4052 S  9.4  0.1 544:39.87 mysqld
 2311 root      20   0     0    0    0 R  3.1  0.0 184:36.36 kondemand/26
 2296 root      20   0     0    0    0 R  3.0  0.0 183:58.76 kondemand/11
 2297 root      20   0     0    0    0 R  3.0  0.0 183:51.36 kondemand/12
 2299 root      20   0     0    0    0 R  3.0  0.0 183:31.22 kondemand/14
 2304 root      20   0     0    0    0 R  3.0  0.0 183:57.42 kondemand/19
 2310 root      20   0     0    0    0 R  3.0  0.0 182:07.21 kondemand/25
 2312 root      20   0     0    0    0 R  3.0  0.0 184:01.70 kondemand/27
 2314 root      20   0     0    0    0 R  3.0  0.0 182:34.96 kondemand/29
 5255 root      20   0 84432  11m 2800 R  3.0  0.0  58:53.71 cPhulkd - proce
 2286 root      20   0     0    0    0 R  2.9  0.0 179:48.98 kondemand/1
 2298 root      20   0     0    0    0 R  2.9  0.0 183:01.25 kondemand/13
 2300 root      20   0     0    0    0 R  2.9  0.0 183:05.85 kondemand/15
 2302 root      20   0     0    0    0 R  2.9  0.0 181:37.64 kondemand/17
 2305 root      20   0     0    0    0 S  2.9  0.0 182:42.13 kondemand/20
 2313 root      20   0     0    0    0 S  2.9  0.0 183:37.13 kondemand/28
 3264 root      20   0  131m 6236 3712 R  2.9  0.0  13:49.84 cpsrvd (SSL) -
 2287 root      20   0     0    0    0 R  2.8  0.0 155:21.99 kondemand/2
 2289 root      20   0     0    0    0 R  2.8  0.0 181:43.40 kondemand/4
 2290 root      20   0     0    0    0 R  2.8  0.0 180:02.76 kondemand/5
 2293 root      20   0     0    0    0 R  2.8  0.0 179:04.75 kondemand/8
 2294 root      20   0     0    0    0 R  2.8  0.0 182:32.23 kondemand/9
 2295 root      20   0     0    0    0 R  2.8  0.0 184:39.21 kondemand/10
 2306 root      20   0     0    0    0 R  2.8  0.0 182:20.72 kondemand/21
 2307 root      20   0     0    0    0 R  2.8  0.0 182:39.74 kondemand/22
 2309 root      20   0     0    0    0 R  2.8  0.0 179:00.80 kondemand/24
 2315 root      20   0     0    0    0 R  2.8  0.0 182:54.88 kondemand/30
 2965 root      20   0  150m  35m 3464 R  2.8  0.1 177:45.39 httpd
 2291 root      20   0     0    0    0 R  2.7  0.0 180:53.41 kondemand/6
 2292 root      20   0     0    0    0 R  2.7  0.0 179:38.78 kondemand/7
 2303 root      20   0     0    0    0 R  2.7  0.0 184:05.13 kondemand/18
 2316 root      20   0     0    0    0 S  2.7  0.0 182:06.84 kondemand/31
18451 cuntschi  20   0  187m  12m 5608 R  2.7  0.0   0:00.29 php
 2285 root      20   0     0    0    0 R  2.6  0.0 176:55.27 kondemand/0
18430 cuntschi  20   0  186m  11m 4960 R  2.6  0.0   0:00.28 php
18445 cocksuck  20   0  175m 9332 5208 R  2.6  0.0   0:00.28 php
18459 romanced  20   0  184m   9m 4972 R  2.6  0.0   0:00.28 php
18463 sexsmovi  20   0  187m  13m 5512 R  2.6  0.0   0:00.28 php
18482 enterpri  20   0  185m  11m 5424 R  2.6  0.0   0:00.28 php
18488 enterpri  20   0  185m  12m 5456 R  2.6  0.0   0:00.28 php
 2301 root      20   0     0    0    0 R  2.5  0.0 178:52.97 kondemand/16
 2308 root      20   0     0    0    0 R  2.5  0.0 181:52.38 kondemand/23
18432 cuntschi  20   0  184m  10m 4956 R  2.5  0.0   0:00.27 php
18434 cocksuck  20   0  187m  12m 5796 R  2.5  0.0   0:00.27 php
18436 sexsmovi  20   0  186m  13m 5480 R  2.5  0.0   0:00.27 php
18439 cuntschi  20   0  184m 9868 4960 R  2.5  0.0   0:00.27 php

それは何であり、どのように停止しますか?

答え1

これは自動CPU周波数スケーリングです。使用中のCPUが実際にアイドルCPUのようです。 CPUベンチマークプログラムを起動してこれをテストできます。 kondemand インスタンス使用量が 0% に低下することがわかります。プログラムatopはCPU拡張率も表示します。

ディストリビューションごとにこの問題を異なる方法で処理します。ディストリビューションを公開していないので見てみましょう。http://www.servernoobs.com/avoiding-cpu-speed-scaling-in-modern-linux-distributions-running-cpu-at-full-speed-tips/?doing_wp_cron=1428304535.599737882614135741出発点へ。このクイックスクリプトはこの機能を完全にオフにしますが、実際にはシステムの起動スクリプトで何が起こっているのかを知りたいと思います。

for CPUFREQ in /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor;
do [ -f $CPUFREQ ] || continue; echo -n performance > $CPUFREQ; done

たぶん電力を節約するよりも悪いことはないかもしれません。ワークロードが非常に急増していない限り、この機能を無効にしても追加の列を取得できません(実際に問題が発生しない限り)。

答え2

あなたの質問に答えるためには、まず kondemand が何であるかを理解する必要があります。

kondemandは、使用統計に基づいてシステムのp状態を変更するcpufreqサブシステムのondemandレギュレータに属するカーネルスレッドです。したがって、電源管理に役立ちます。 参照要求

  • 今、あなたの質問はなぜCPUを使用するのですか?

回答:あなたのコンピュータには32のコアがあるようです。それで、32個の kondemand スレッドが実行されているのです。各スレッドは、CPU周波数を最適化するために少しのCPUを消費します。このCPU使用率は通常、CPUがアイドル状態のときに発生します。この点で kondemand は cpufreq に関連するカーネルスレッドです。だから電力を節約するように設計されています。忙しい時にはプロセッサをロードしないでください。

kondemandを無効にする場合も、以下のリンクに記載されている手順に従ってください。

上記のリンクには、あなたが言及した問題の良い説明があります。また、kondemandの無効化/有効化の影響を確認できます。

カーネルのバージョンに応じて kondemand を無効にする方法は 2 つあります。どのバージョンのカーネルを使用しているのかわかりません。したがって、上記のリンクを確認して、システムにインストールされているカーネルのバージョンに応じて必要なアクションを実行する必要があります。

頑張ってください!

関連情報