Cron作业不执行perl脚本

时间:2012-02-10 08:00:55

标签: cron centos

这是我的perl脚本,它只是一个测试。

#!/usr/local/bin/perl
open (MYFILE, '>>data.txt');
print MYFILE "Worked!\n";
close (MYFILE);

我在cgi-bin /

中将其保存为test.pl

当我运行shell命令时,

root @ srv ./test.pl 它工作正常,它增加了“工作!”在data.txt文件中成功。

但是当我在cronjob中添加它来运行每分钟时它不起作用 代码:

*/1 * * * * root cd /home/testing/public_html/cgi-bin;./test.pl

我也试过

*/1 * * * * cd /home/testing/public_html/cgi-bin;./test.pl

我认为cron的环境设置不正确,但我不知道如何修复它。

我在crontab中使用它来执行env

*/1 * * * * env > /home/tmp2/env.cron

结果如下:

SHELL=/bin/sh
USER=root
PATH=/usr/local/jdk/bin:/usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin:/usr/X11R6/bin:/root/bin
PWD=/root
SHLVL=1
HOME=/root
LOGNAME=root
_=/bin/env

然后我将我正在使用的shell的env导出到另一个文件env.shell 结果:

HOSTNAME=srv.testing.com
SELINUX_ROLE_REQUESTED=
TERM=xterm
SHELL=/bin/bash
HISTSIZE=1000
SSH_CLIENT=xxx.xx.xxx.xx 58048 22
SELINUX_USE_CURRENT_RANGE=
QTDIR=/usr/lib64/qt-3.3
QTINC=/usr/lib64/qt-3.3/include
SSH_TTY=/dev/pts/0
USER=root
LS_COLORS=rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:su=37;41:sg=30;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arj=0$
MAIL=/var/spool/mail/root
PATH=/usr/local/jdk/bin:/usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin:/usr/X11R6/bin:/root/bin
PWD=/home/tmp2
JAVA_HOME=/usr/local/jdk
EDITOR=pico
LANG=en_US.UTF-8
SELINUX_LEVEL_REQUESTED=
HISTCONTROL=ignoredups
SHLVL=1
HOME=/root
LS_OPTIONS=--color=tty -F -a -b -T 0
LOGNAME=root
VISUAL=pico
QTLIB=/usr/lib64/qt-3.3/lib
CVS_RSH=ssh
CLASSPATH=.:/usr/local/jdk/lib/classes.zip
SSH_CONNECTION=xxx.xx.xxx.xx 58048 xx.xx.xx.xx 22
LESSOPEN=|/usr/bin/lesspipe.sh %s
G_BROKEN_FILENAMES=1
_=/bin/env
OLDPWD=/home/testing/public_html/cgi-bin

我复制了shell路径

 PATH=/usr/local/jdk/bin:/usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin:/usr/X11R6/bin:/root/bin

并将其添加到/ etc / crontab并重新启动cron但它仍然无法正常工作。所以,我把它改回正常,然后我用crontab -e将它添加到crontab,但它仍然无法帮助。

我不确定发生了什么,

感谢您的时间

2 个答案:

答案 0 :(得分:1)

我终于解决了!

我改变了crontab -e

的路径
PATH=/usr/local/jdk/bin:/usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin:/usr/X11R6/bin:/root/bin

如果你这样做的话,我的shell中的路径是相同的 root#env> env.shell root #nano env.shell 然后从那里复制路径,并使用crontab -e

将其粘贴到crontab中

然后,最后一步是将它添加到crontab -e,但是在我添加了路径后,我在/etc/cron.d/sysstat中使用了cronjob,这就是为什么它无法正常工作。

现在它起作用了,主要问题是PATH。

感谢大家的时间。

答案 1 :(得分:0)

尝试

* * * * * root cd "/home/testing/public_html/cgi-bin"; ./test.pl