关于crontab的编写  网上一大堆,在这不在解释

如下


0 1 * * *  /usr/local/oakcloud/shell/synchronizeTime > /dev/null 2>&1


这是每一个小时开机运行的一个cron  执行的是synchronizeTime 这个脚本,将一些信息输出 直接仍进黑洞里 ,一些错误的信息放在制定的文件里.

在syncronizeTime 中有一个错误log的输出:


date=`date +%Y-%m-%d%H:%M`

echo $date '连通' >>network.log


但是奇怪的是在/usr/local/oakcloud/shell/下 没有network.log文件的输出.

在命令行直接


./synchronizeTime


可以看到network.log的输出.

 

后来多了解下crontab  发现如果在这里面的隐藏的信息  root用户执行这个语句.

所以network.log 一定在/root里,后来验证了这个猜想.

所以,这个解决方法有两种:

1.重定向文件时写绝对路径,一定没错.

2.执行crontab时使用 系统用户执行

    crontab -u user filename