landscape-sysinfo reports exaggerated temperatures
Affects | Status | Importance | Assigned to | Milestone | |
---|---|---|---|---|---|
landscape-client (Ubuntu) |
Confirmed
|
Undecided
|
Unassigned |
Bug Description
When running landscape-sysinfo the temperature that is reported is often exaggerated compared to other measurements taken by e.g. running 'sensors'. After some testing it seems that the temperatures that are reported are correctly read from the thermal_zone information; however, the act of running the landscape-sysinfo script inflates the measurement at the time it is taken. Likely this is because of an increased CPU load just prior to the measurement.
I imagine the impact of this issue will depend widely on the specific hardware that is used and the types of thermal zones reported. Nonetheless, I found that the impact of the issue can be greatly reduced by including a 50ms 'sleep' in the ThermalZone class just before reading the temperature value. For example, adding a "time.sleep(0.05)" before the line "self.temperatu
Adding a small wait time before the temperature reading will increase the run time of the script, but since the wait interval is so short it isn't noticeable. The only exception might be systems with a very large number of thermal zones (e.g. 10 zones would increase the total delay to 0.5 sec). Perhaps there are other more elegant ways to ensure that the temperature measurement is more accurate, such as changing the run order of the different sysinfo components to ensure the lowest CPU usage at the time temperatures are taken. Hopefully this can be integrated in a future release to have more realistic temperature reporting.
We are running into the same issue, after adding a small delay of only 0.05 seconds the temperature shown will be +/- 20C lower. This is on Ubuntu 22.04.3 LTS.
root@hostname:~# landscape-sysinfo |grep Temperature
Temperature: 59.0 C
But when I modify landscape-sysinfo from: sys.argv[ 1:], reactor) sleep(0. 05) sys.argv[ 1:], reactor)
---------
if __name__ == "__main__":
run(
---------
To:
---------
if __name__ == "__main__":
import time
time.
run(
---------
The temperature shown will then be 21C lower:
root@hostname:~# landscape-sysinfo |grep Temperature
Temperature: 38.0 C
The temperature shown will then be the same as the temperature shown by the sensors command:
root@hostname:~# sensors
coretemp-isa-0000
Adapter: ISA adapter
Package id 0: +38.0°C (high = +100.0°C, crit = +100.0°C)