Linux:Crontab定时任务执行脚本不成功,但手动执行成功

一、说明

使用jcmd和lsof命令监控程序线程异常占用情况,在Crontab增加了定时任务,每半小时输出一次内容。设置定时任务后,发现jcmd内容可正常输出,lsof只生成文件不输出内容,但手动执行脚本可以输出内容。

#!/bin/bash
jarpid=`jps -l|grep jar包|grep -v 'grep'|awk '{print $1}'`
time=`date "+%Y-%m-%d %H:%M:%S"`

jcmd ${jarpid} Thread.print -l >> jar包路径/jcmd_${time}.txt
lsof -p ${jarpid} >> jar包路径/lsof_${time}.txt

二、解决办法

crontab有一个问题,就是它不会从profile文件中读取环境变量参数,经常导致在手工执行某个脚本时是成功的,但是到crontab中试图让它定期执行时就是会出错。

所以原因就在于,crontab没有去读环境变量,需要再脚本中手动引入环境变量。

在脚本中加入了引入环境变量的配置:

#!/bin/bash
source /etc/profile
source ~/.bash_profile

jarpid=`jps -l|grep jar包|grep -v 'grep'|awk '{print $1}'`
time=`date "+%Y-%m-%d %H:%M:%S"`

jcmd ${jarpid} Thread.print -l >> jar包路径/jcmd_${time}.txt
lsof -p ${jarpid} >> jar包路径/lsof_${time}.txt

问题解决!

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值