Привет, я запускаю малину Pi, используя OSMC и веб-сервер на том же Pi.Crontab и скрипт питона записываются в файл
Ive создал скрипт python, который получает temp, использование, память и т. Д. Когда я запускаю скрипт, используя: sudo python state.py
, он работает, он получает значения и записывает их в файл txt.
Я хочу, чтобы скрипт для запуска при запуске, так что я сделал кронтаб:
@reboot sudo python /home/osmc/python/state.py &
Это работает, однако доцент написать статистику CPU в файл, только память и статистику диска.
Мой питон скрипт выглядит следующим образом:
#!/usr/bin/python
import os
import sys
import commands
import time
# Return CPU temperature as a character string
def getCPUtemperature():
res = os.popen('vcgencmd measure_temp').readline()
return(res.replace("temp=","").replace("'C\n",""))
# Return RAM information (unit=kb) in a list
# Index 0: total RAM
# Index 1: used RAM
# Index 2: free RAM
def getRAMinfo():
p = os.popen('free')
i = 0
while 1:
i = i + 1
line = p.readline()
if i==2:
return(line.split()[1:4])
# Return % of CPU used by user as a character string
def getCPUuse():
return(str(os.popen("top -n1 | awk '/Cpu\(s\):/ {print $2}'").readline().strip(\
)))
# Return information about disk space as a list (unit included)
# Index 0: total disk space
# Index 1: used disk space
# Index 2: remaining disk space
# Index 3: percentage of disk used
def getDiskSpace():
p = os.popen("df -h /")
i = 0
while 1:
i = i +1
line = p.readline()
if i==2:
return(line.split()[1:5])
while True:
# CPU informatiom
CPU_temp = getCPUtemperature()
CPU_usage = getCPUuse()
# RAM information
# Output is in kb, here I convert it in Mb for readability
RAM_stats = getRAMinfo()
RAM_total = round(int(RAM_stats[0])/1000,1)
RAM_used = round(int(RAM_stats[1])/1000,1)
RAM_free = round(int(RAM_stats[2])/1000,1)
# Disk information
DISK_stats = getDiskSpace()
DISK_total = DISK_stats[0]
DISK_free = DISK_stats[1]
DISK_perc = DISK_stats[3]
starttime = time.time()
file = open("/var/www/html/rspi_state.txt", "w")
file.write(CPU_temp + "\n")
file.write(CPU_usage + "\n")
file.write(DISK_stats[1] + "\n")
file.write(DISK_stats[0] + "\n")
file.write(DISK_stats[3] + "\n")
file.write(str(RAM_total) + "\n")
file.write(str(RAM_free) + "\n")
file.close()
print "CPU TEMP: " + CPU_temp
time.sleep(9.0 - ((time.time() - starttime) % 9.0))
Есть ли причина, почему это только писать некоторые данные в текстовый файл? Любая помощь очень ценится!
'ОС, popen' thows прочь' strerr' и код возврата, так что вы не обрабатываем случай, когда срывается вызов. Используйте один из вызовов в подпроцессе, который либо вызывает исключение при сбое, либо позволяет читать stderr и проверять коды возврата самостоятельно. – tdelaney
Благодарим за комментирование. Он работает, если я просто запускаю скрипт из ssh. Является ли ошибка из-за использования cron? –
Не 'sudo' внутри' cron'. Просто добавьте скрипт в crontab 'root', используя' sudo crontab -e'. Кроме того, у вас уже есть интерпретатор в вашем скрипте, поэтому вы можете добавить '@reboot /home/osmc/python/state.py &' в crontab root, и он должен работать нормально. – Munir