[root@localhost ~]# time cpumode
Driver: acpi-cpufreq
Boost: disabled
Governor: ondemand
Average and maximum frequencies now: 2159MHz 2929MHz
Maximum allowed frequency is 3800MHz (out of 4928MHz)
real 0m0.214s
user 0m0.017s
sys 0m0.011s
[root@localhost ~]# time cpumode
Driver: acpi-cpufreq
Boost: disabled
Governor: ondemand
Average and maximum frequencies now: 2431MHz 2738MHz
Maximum allowed frequency is 3800MHz (out of 4928MHz)
real 0m0.024s
user 0m0.018s
sys 0m0.013s
スクリプトの実行にかかる時間にはほとんど大きな違いがあり、ランダムに発生します。
どのように可能かわかりません。デバッグが有効な場合(最初の2行はコメントアウトされません)スクリプト常に0.134秒程度で動作します。
PC/ノートブックで再生できない場合でも心配しないでください。これは私の人生で一度も見たことがなく、説明できない奇妙な現象だ。次のように実行できますが、strace -f -t
今はそうしたくありません;-)
Linux 5.19.4では、この動作を再現することはできません。
答え1
同様の違いがあります。これは、CPU全体でプロセスをスケジュールする方法に関連しているようです。
「遅い」実行時の出力は次のとおりです。
./cpumode > /dev/null 0.03s user 0.01s system 19% cpu 0.189 total
または
0.03user 0.01system 0:00.20elapsed 21%CPU (0avgtext+0avgdata 4004maxresident)k
0inputs+0outputs (0major+5720minor)pagefaults 0swaps
(zsh
stime
とGNUをそれぞれ使用します。出力を気にせず要因の場合は、ターミナル遅延を排除するために両方にtime
リダイレクトします。)> /dev/null
速く走っている間
./cpumode > /dev/null 0.03s user 0.02s system 125% cpu 0.035 total
または
0.03user 0.01system 0:00.03elapsed 125%CPU (0avgtext+0avgdata 4092maxresident)k
0inputs+0outputs (0major+5668minor)pagefaults 0swaps
CPU割り当ての違いを確認してください。