크론 작업 설정은 다음과 같습니다.
*/15 * * * * speedtest >> /home/pi/speedtest.log
스크립트는 speedtest
다음과 같습니다
#!/bin/sh
speedtest-cli --csv >> /home/pi/speedtest.log
Speedtest-CLI를 사용하세요. 작업은 정시에 실행되지만 내가 얻는 것은 다음 cron 출력뿐입니다.
Jul 19 08:17:01 raspberrypi CRON[29275]: (root) CMD ( cd / && run-parts --report /etc/cron.hourly)
Jul 19 08:30:01 raspberrypi CRON[29378]: (pi) CMD (speedtest >> /home/pi/speedtest.log)
Jul 19 08:30:01 raspberrypi CRON[29377]: (CRON) info (No MTA installed, discarding output)
Jul 19 08:45:01 raspberrypi CRON[29430]: (pi) CMD (speedtest >> /home/pi/speedtest.log)
Jul 19 08:45:01 raspberrypi CRON[29429]: (CRON) info (No MTA installed, discarding output)
Jul 19 09:00:01 raspberrypi CRON[29608]: (pi) CMD (speedtest >> /home/pi/speedtest.log)
Jul 19 09:00:01 raspberrypi CRON[29607]: (CRON) info (No MTA installed, discarding output)
Jul 19 09:15:01 raspberrypi CRON[29791]: (pi) CMD (speedtest >> /home/pi/speedtest.log)
Jul 19 09:15:01 raspberrypi CRON[29790]: (CRON) info (No MTA installed, discarding output)
하지만 speedtest.log가 업데이트되는 것을 볼 수 없습니다. 무슨 일이야?
답변1
작업이 에 의해 실행 중이 cron
거나 systemd
시작 스크립트가 데스크탑에서 실행 중인 것과 동일한 런타임 환경에서 실행되고 있지 않습니다. systemd
로 스크립트를 시작합니다 root
. 변경 사항이나 기타 환경 변수 설정은 작업 PATH
에 자동으로 전파되지 않습니다 cron
. 예를 들어 no $DISPLAY
이므로 GUI 프로그램에는 특별한 처리(읽기 man xhost
)가 필요합니다.
cron
환경 변수는 모든 작업에 대한 읽기 파일에서 설정할 수 있습니다 .crontab
man 5 crontab
echo "=== id ===";id;echo "=== set ===";set;echo "=== env ===";env | sort;echo "=== alias ===";alias
각 환경의 결과를 확인하세요.
해당 줄은 기본적으로 해석되기 때문에 command
구문이 그보다 간단하므로 환경을 설정한 후 필요한 프로그램을 호출하는 스크립트(실행 가능, 설치, 시작)를 호출하는 것이 좋습니다.crontab
/bin/sh
/bin/bash
command
bash
#!/bin/bash