shell脚本手动执行无问题,放在计划任务里面就不正常了,请大神指教! 10
写了个保护进程的脚本,内容如下:#!/bin/bashkeepalive=$(ps-ef|grepkeepalive.sh|awk'{print$9}'|head-1)k...
写了个保护进程的脚本,内容如下:
#!/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等形式都没成功 展开
#!/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等形式都没成功 展开
2个回答
展开全部
脚本中的环境变量 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
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
追问
您发的内容跟我提问的问题毫无关系啊,我这么简单的脚本,用的也都是系统本身的命令,脚本也用的绝对路径,根本涉及不到环境变量
展开全部
理论上没有问题啊,你确定十分钟后那个判断是成立的吗?crontab 调起9分钟后你看看后台进程 看看还有吗?
追问
我手动测试都是成立的,手动无论执行多少次,只要有keepalive.sh进程了,就不会再多启动这个进程。奇怪的就是放到计划任务里运行了,就会启动多个keepalive.sh
追答
不好意思,我也不能理解,你确定是同一个服务器吗?
还是 我刚才说的 crontab调起之后你查过进程吗,有没有,第二次调起之后就会出现两个进程?crontab调起之后 你手动执行脚本,也就是crontab调起 存在后,再手动执行脚本还能成功吗?
这个问题我没碰见过,我也不是很清楚哈,就是感兴趣
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询