用crontab 配置上次写的监控脚本,定时重启一个java应用,遇到两个问题:
首先,这个java程序是由一个脚本程序来启动的,直接 sh 脚本程序,可以正确启动执行,但是直接加到crontab中却不能正确执行。因为这个脚本执行所需的CLASSPATH变量是在用户的profile中设定的,怀疑crontab中启动的程序并不能直接获得系统设定的环境变量,于是把系统环境变量中的CLASSPATH在脚本中重新export了一下,重新设置crontab就可以启动这个程序了。
然后,程序启动后ps发现了多了两个进程,
...............[sh] <defunct>
...............usr/sbin/sendmail -FCronDaemon -i -odi -oem -oi -t
上面那个是一个僵死进程,
经google了解这个问题一般是由于crontab里的程序输出大量信息到标准输出设备造成的,输出的信息触发了系统的sendmail,把信息当作邮件发给用户。
解决方法也很简单,就是把输出重定向到空设备即可。所以把脚本里执行java程序的命令改成 /usr/bin/java xxxxxx > /dev/null 2>&1 ,就是把标准输出重定向到空设备,把输出的错误信息也重定向到标准输出设备(也不显示在输出设备上了,因为前面已经屏蔽标准输出设备了)。
这里涉及到管道的问题,
0:标准输入设备
1:标准输出设备
2:标准错误设备