shell脚本手动执行无问题,放在计划任务里面就不正常了,请大神指教!

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了shell脚本手动执行无问题,放在计划任务里面就不正常了,请大神指教!相关的知识,希望对你有一定的参考价值。

写了个保护进程的脚本,内容如下:
#!/bin/bash
keepalive=$(ps -ef|grep keepalive.sh|awk 'print $9'|head -1)
keepalive=$keepalive##*/
if [ "$keepalive" = "keepalive.sh" ]
then
echo "$(date) The keepalive is ok!" >> /rsdata/log/keepalive-monitor-acc.log
else
/etc/netdetective/rain-soft/keepalive.sh >/dev/null 2>&1 &
echo "$(date) The keepalive restarted!" >> /rsdata/log/keepalive-monitor-err.log
fi
将keepalive.sh结束掉,运行脚本能够启动keepalive.sh,再次运行多次脚本,也不会重复启动keepalive.sh。手动测试这个脚本都没问题。
但是,我将这个脚本放到计划任务里去每10分钟执行一次,就不正常了。启动了keepalive.sh后,下个10分钟就又把keepalive.sh给启动一次,再下个10分钟又给启动一个,然后keepalive.sh又不再增加了。太奇怪了,请大神指教下哪里有问题?crontab里是这么写的*/10 * * * * root /etc/netdetective/rain-soft/monitor-keepalive.sh。
另外,函数keepalive尝试过用-n、-z等形式都没成功

脚本中的环境变量 env > env.log 打出为:
1 HOME=/home/kk
2 OLDPWD=/home/kk
3 LOGNAME=kk
4 PATH=/usr/bin:/bin
5 SHELL=/bin/sh
6 PWD=/home/kk/weibo/a
明显是很多不同的, 而且PATH少了很多设置。

因此想办法在shell脚本的开头加上这些东西:
1 #!/bin/bash
2 PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games

3 SHELL=/bin/bash
4 JAVA_HOME=/usr/lib/jvm/java-6-sun
5 _=/usr/bin/env
6
7
8 env > env.log
9 . /etc/profile
10 . ~/.profile
shit! 结果还是失败!!!

解决办法: ==========================================》
方法一:
在/etc/crontab 文件中直接添加我的crontab job任务即可。 但是此法需要root权限才能修改此文件, 在我的本机是可以的;但是我在服务器上面就是不可以了,没有root权限。
方法二:
在crontab -e 中的头部加上PATH, 该PATH和命令行下env得到的PATH一样。
me@server:~/$ crontab -l
# m h dom mon dow command
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games追问

您发的内容跟我提问的问题毫无关系啊,我这么简单的脚本,用的也都是系统本身的命令,脚本也用的绝对路径,根本涉及不到环境变量

参考技术A 理论上没有问题啊,你确定十分钟后那个判断是成立的吗?crontab 调起9分钟后你看看后台进程 看看还有吗?追问

我手动测试都是成立的,手动无论执行多少次,只要有keepalive.sh进程了,就不会再多启动这个进程。奇怪的就是放到计划任务里运行了,就会启动多个keepalive.sh

追答

不好意思,我也不能理解,你确定是同一个服务器吗?
还是 我刚才说的 crontab调起之后你查过进程吗,有没有,第二次调起之后就会出现两个进程?crontab调起之后 你手动执行脚本,也就是crontab调起 存在后,再手动执行脚本还能成功吗?
这个问题我没碰见过,我也不是很清楚哈,就是感兴趣

shell 脚本手动执行能成功,但是放在定时任务执行不成功

原因:cron的环境变量和shell脚本的环境变量不一样

解决办法:

方法一:定时任务里面切换到root执行(亲测可用)

*/5 * * * * su - root -c "/opt/test.sh"

 方法二:在脚本里面添加环境变量(未测试过)

vi /opt/tes.sh
#!/bin/bash
source /etc/profile
source ~/.bash_profile
...你的代码块

 

以上是关于shell脚本手动执行无问题,放在计划任务里面就不正常了,请大神指教!的主要内容,如果未能解决你的问题,请参考以下文章

shell 脚本手动执行能成功,但是放在定时任务执行不成功

linux脚本放到计划任务里面执行结果与手动运行不一致

用计划任务运行bat脚本结果和手动运行脚本不一致,脚本内容只有一条move

linux计划任务执行脚本显示乱码

linux shell 手动执行tomcat 和 计划任务重启tomcat 不一致。

用shell把写需要定时执行的脚本写进计划任务