今天在公司服务器上设置一个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