1

我创建了一个脚本来检查我的 glassfish 服务器是否正在运行(安装在 freebsd 系统上),如果没有,脚本会尝试终止 java 进程以确保它没有挂起,然后发出asadmin start -域命令

如果此脚本从命令行运行,则100% 的时间是成功的。当它从 cron 选项卡运行时,除了asadmin start-domain行之外的每一行都运行 - 它似乎没有执行或至少没有完成,即该脚本运行后服务器没有运行。

对于不熟悉 glassfish 或用于启动服务器的 asadmin 实用程序的任何人,我的理解是使用了分叉进程。这会通过cron引起问题吗?

同样,在我今天的所有测试中,脚本在从命令行运行时会运行到完成。一旦它通过 cron 执行,它就不会完成......从 crontab 运行它会有什么不同???

提前感谢您的帮助...我正在努力完成这项工作!

#!/bin/bash

JAVA_HOME=/usr/local/diablo-jdk1.6.0/; export JAVA_HOME

timevar=`date +%d-%m-%Y_%H.%M.%S` 
process_name='java'
get_contents=`cat urls.txt`  

for i in $get_contents
do
echo checking $i
statuscode=$(curl --connect-timeout 10  --write-out %{http_code} --silent --output /dev/null $i)
case $statuscode in
    200)
        echo "$timevar $i $statuscode okay" >> /usr/home/user1/logfile.txt
        ;;
    *)
        echo "$timevar $i $statuscode bad" >> /usr/home/user1/logfile.txt
        echo "Status $statuscode found" | mail -s "Check of $i failed" some.address@gmail.com
        process_id=`ps acx | grep -i $process_name | awk {'print $1'}`
        if [ -z "$process_id" ]
        then
            echo "java wasn't found in the process list"
        else
            echo "Killing java, currently process $process_id"
            kill -9 $process_id
        fi
        /usr/home/user1/glassfish3/bin/asadmin start-domain domain1
        ;;
esac
done

此外,为了完整起见,这里是 cron 选项卡中的条目:

*/2 * * * *  /usr/home/user1/server.check.sh >> /usr/home/user1/cron.log
4

1 回答 1

0

好的......在另一个网站上找到了这个答案,但我想我会在这里添加答案以供将来参考。

问题是路径!即使设置了 java_home,java 本身也不在 cron 守护进程的路径中。

快速测试以查看您的 cron 可用的路径,添加以下行:

*/2 * * * * env > /usr/home/user1/env.output

据我所知,cron 最初可用的 PATH 非常少。由于 java 在 /usr/local/bin 中,我将它添加到 crontab 和 kaboom 中的路径中!有效!

PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin

*/2 * * * * /usr/home/user1/server.check.sh >> /usr/home/user1/cron.log
于 2013-02-22T16:43:34.713 回答