Cron 작업이 작동하지 않습니다(또는 적어도 작동해야 하는 파일에 로깅).

Cron 작업이 작동하지 않습니다(또는 적어도 작동해야 하는 파일에 로깅).

크론 작업 설정은 다음과 같습니다.

*/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환경 변수는 모든 작업에 대한 읽기 파일에서 설정할 수 있습니다 .crontabman 5 crontab

echo "=== id ===";id;echo "=== set ===";set;echo "=== env ===";env | sort;echo "=== alias ===";alias각 환경의 결과를 확인하세요.

해당 줄은 기본적으로 해석되기 때문에 command구문이 그보다 간단하므로 환경을 설정한 후 필요한 프로그램을 호출하는 스크립트(실행 가능, 설치, 시작)를 호출하는 것이 좋습니다.crontab/bin/sh/bin/bashcommandbash#!/bin/bash

관련 정보