免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2306 | 回复: 4
打印 上一主题 下一主题

求助各位关于shell问题,手工执行正确,crontab执行失败! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-11-26 10:43 |只看该作者 |倒序浏览
  1. #/bin/ksh
  2. DATE=`date +%Y%m%d`;
  3. if [ ! -f /tmp/getlog.tmp ]; then
  4.         touch /tmp/getlog.tmp
  5.         echo 1 > /tmp/getlog.tmp
  6. fi
  7. COUNT=`cat /tmp/getlog.tmp`
  8. LOGCOUNT=`cat $HOME/log/log/dcclog/AG0172504.log|wc -l`
  9. LOGPATH="$HOME/log/log/dcclog/AG0172504.log"
  10. TMPPATH="/tmp/getlog.log"
  11. if [ $COUNT -lt $LOGCOUNT ]; then
  12.         for i in `grep -n SendTo $LOGPATH|awk -F ':' '{print $1}'`       
  13.         do
  14.         if [ $i -gt $COUNT ];then
  15.                 icount=`expr $i + 2`
  16.                 sysDate=`sed -n ${icount}p $LOGPATH|awk -F'___' '{print substr($3,9,8)}'`
  17.                 sysTime=`sed -n ${icount}p $LOGPATH|awk -F'___' '{print substr($4,9,6)}'`
  18.                 icount=`expr $icount + 3`
  19.                 sysTmp=`sed -n ${icount}p $LOGPATH|awk -F' ' '{print $1}'`
  20.                 if [ X$sysTmp = "XINM_CHANNEL_TYPE" ];
  21.                 then
  22.                         icount=`expr $icount + 22`
  23.                         sysCustAcct=`sed -n ${icount}p $LOGPATH|awk -F' ' '{print $3}'`
  24.                         icount=`expr $icount + 1`
  25.                         sysAcctNo=`sed -n ${icount}p $LOGPATH|awk -F' ' '{print $3}'`
  26.                         icount=`expr $icount + 2`
  27.                         sysAmt=`sed -n ${icount}p $LOGPATH|awk -F' ' '{print $3}'`
  28.                         icount=`expr $icount + 5`
  29.                         sysRmrk=`sed -n ${icount}p $LOGPATH|awk -F' ' '{print $3}'`
  30.                 else
  31.                         icount=`expr $icount + 18`
  32.                         sysCustAcct=`sed -n ${icount}p $LOGPATH|awk -F' ' '{print $3}'`
  33.                         icount=`expr $icount + 1`
  34.                         sysAcctNo=`sed -n ${icount}p $LOGPATH|awk -F' ' '{print $3}'`
  35.                         icount=`expr $icount + 2`
  36.                         sysAmt=`sed -n ${icount}p $LOGPATH|awk -F' ' '{print $3}'`
  37.                         icount=`expr $icount + 5`
  38.                         sysRmrk=`sed -n ${icount}p $LOGPATH|awk -F' ' '{print $3}'`
  39.                 fi
  40.                 echo "------------------------------------------------" >> $TMPPATH
  41.                 date >> $TMPPATH
  42.                 echo [$sysDate][$sysTime][$sysCustAcct][$sysAcctNo][$sysAmt][$sysRmrk]>> $TMPPATH
  43.                 echo "insert into log1725 values('$sysDate','$sysTime','$sysCustAcct','$sysAcctNo','$sysAmt','$sysRmrk');">/tmp/log1725.tmp
  44.                 dbaccess agent 2>/dev/null < /tmp/log1725.tmp > /tmp/temp$DATE.dat
  45.                 echo "数据库执行结果:"$? >> $TMPPATH
  46.                 echo $icount > /tmp/getlog.tmp
  47.         fi
  48.         done       
  49. fi
复制代码
手工执行的时候,数据能插入到数据库中,但是加入到crontab后,日志出来时均报数据库127错误:
------------------------------------------------------------------------------------------
------------------------------------------------
Thu Nov 25 20:12:11 BEIST 2010
[20101125][192004][4213491590073462][10133198367956276000000001][11.00000000][移动POS消费]
数据库执行结果:127
------------------------------------------------
------------------------------------------------
Thu Nov 25 20:12:11 BEIST 2010
[20101125][194100][4213491590073462][10133198367956276000000001][11.00000000][移动POS消费]
数据库执行结果:127
------------------------------------------------
------------------------------------------------
Fri Nov 26 10:35:00 BEIST 2010
[20101126][103431][6227001592010365722][10133100280016309900810710][10000.00000000][保管箱存款]
数据库执行结果:127

请各位大佬帮忙看下。。

论坛徽章:
0
2 [报告]
发表于 2010-11-26 10:54 |只看该作者
检查下 是否缺少连接数据库所需的环境变量。。。。

论坛徽章:
0
3 [报告]
发表于 2010-11-26 11:26 |只看该作者

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
4 [报告]
发表于 2010-11-26 11:50 |只看该作者
脚本太长啦。还是用ksh的。

论坛徽章:
0
5 [报告]
发表于 2010-11-29 13:54 |只看该作者
环境变量的问题。
在你的脚本里面声明一下系统的环境变量。
应该就可以解决了。
之前我也遇到过这种问题。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP