今天在公司服务器上设置一个crontab,*/1 * * * * /bin/sh /data/tool/jstack.sh,手动sh /data/tool/jstack.sh是可以执行的,但放到crontab里却无法运行,对脚本头部加上#!/bin/bash还是没有运行.而jstack.sh里的内容是:
#!/bin/bash echo 堆栈信息记录开始 jstack 24238 >> /data/log/monitor/jstack_$(date +"%Y%m%d%H%M").log echo "文件路径 /data/log/monitor/jstack_$(date +"%Y%m%d%H%M").log" echo 堆栈信息记录完毕
然后再等crontab执行,发现成功.网上搜了下发现了问题所在:
crontab有一个坏毛病,就是它总是不会缺省的从用户profile文件中读取环境变量参数,经常导致在手工执行某个脚本时是成功的,但是到crontab中试图让它定期执行时就是会出错.
看了这个就知道怎么修改脚本了,脚本的头上用缺省的#!/bin/sh就可以,然后然后第一个部分先写这些:
###################
. /etc/profile
. ~/.bash_profile
##################
这样crontab在执行脚本的时候,就能够读到用户的环境变量参数.如下:
#!/bin/sh . /etc/profile . ~/.bash_profile echo 堆栈信息记录开始 jstack 24238 >> /data/log/monitor/jstack_$(date +"%Y%m%d%H%M").log echo "文件路径 /data/log/monitor/jstack_$(date +"%Y%m%d%H%M").log" echo 堆栈信息记录完毕
这样就不用在脚本里写全php路径了.
00 01 * * * /bin/sh /usr/local/shells/timesyn.sh
59 23 * * * /bin/sh /data/tool/log.sh
*/1 * * * * /bin/sh /data/tool/jstack.sh