Niech „cron” uruchomi skrypt powłoki, który ustawia środowisko przed uruchomieniem polecenia.
Zawsze.
# @(#)$Id: crontab,v 4.2 2007/09/17 02:41:00 jleffler Exp $
# Crontab file for Home Directory for Jonathan Leffler (JL)
#-----------------------------------------------------------------------------
#Min Hour Day Month Weekday Command
#-----------------------------------------------------------------------------
0 * * * * /usr/bin/ksh /work1/jleffler/bin/Cron/hourly
1 1 * * * /usr/bin/ksh /work1/jleffler/bin/Cron/daily
23 1 * * 1-5 /usr/bin/ksh /work1/jleffler/bin/Cron/weekday
2 3 * * 0 /usr/bin/ksh /work1/jleffler/bin/Cron/weekly
21 3 1 * * /usr/bin/ksh /work1/jleffler/bin/Cron/monthly
Wszystkie skrypty w ~ / bin / Cron są linkami do jednego skryptu „runcron”, który wygląda następująco:
: "$Id: runcron.sh,v 2.1 2001/02/27 00:53:22 jleffler Exp $"
#
# Commands to be performed by Cron (no debugging options)
# Set environment -- not done by cron (usually switches HOME)
. $HOME/.cronfile
base=`basename $0`
cmd=${REAL_HOME:-/real/home}/bin/$base
if [ ! -x $cmd ]
then cmd=${HOME}/bin/$base
fi
exec $cmd ${@:+"$@"}
(Napisane przy użyciu starszego standardu kodowania - w dzisiejszych czasach na początku używałbym przekreślenia „#!”).
„~ / .Cronfile” to odmiana w moim profilu do użytku przez crona - rygorystycznie nieinteraktywna i bez echa ze względu na bycie głośnym. Zamiast tego możesz skonfigurować plik .profile i tak dalej. (Rzeczy REAL_HOME to artefakt mojego środowiska - możesz udawać, że jest taki sam jak $ HOME.)
Tak więc ten kod odczytuje odpowiednie środowisko, a następnie wykonuje wersję polecenia inną niż Cron z mojego katalogu domowego. Na przykład moje polecenie „dzień tygodnia” wygląda następująco:
: "@(#)$Id: weekday.sh,v 1.10 2007/09/17 02:42:03 jleffler Exp $"
#
# Commands to be done each weekday
# Update ICSCOPE
n.updics
Polecenie „codzienne” jest prostsze:
: "@(#)$Id: daily.sh,v 1.5 1997/06/02 22:04:21 johnl Exp $"
#
# Commands to be done daily
# Nothing -- most things are done on weekdays only
exit 0