免费注册 查看新帖 |

Chinaunix

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

shell变量赋值有缓存? [复制链接]

论坛徽章:
1
双子座
日期:2013-10-17 00:46:45
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-10-12 20:31 |只看该作者 |倒序浏览
一个奇怪的问题:
1、程序如下:
  1. findTotalorMax(){
  2.         if [[ $4 == "--total" ]]
  3.         then
  4.                 /data/script/GetData -t 1 -d `date -d"$3 days ago" +'%F %T'`  -i $1  -a $2|tac|awk -F":" '/total:/{print $2+0;exit}'
  5.                
  6.         elif [[ $4 == "--max" ]]
  7.         then
  8.                 /data/script/GetData -t 1 -d `date -d"$3 days ago" +'%F %T'`  -i $1  -a $2|tac|awk -F":" '/max value:/{print $2+0;exit}'
  9.         fi
  10.        
  11. }

  12. oid97893_1=`findTotalorMax 2808  97893 1 --total`
复制代码
ps:
脚本有点长,近千行,这个就是对应的调试信息的语句
GetData 是 c++封装好的一个小工具

2、调试代码信息如下:
  1. 脚本执行:
  2. ++ /data/script/GetData -t 1 -d 2011-09-16 18:23:54 -i 2808 -a 97893
  3. + [color=Red]oid97893_1=4198[/color]

  4. ++ /data/script/GetData -t 1 -d 2011-09-17 18:23:33 -i 2808 -a 97893
  5. + [color=Red]oid97893_1=4198[/color]
复制代码
ps:
真诡异,执行30次,所有的取值都和第一次的值一样

3、单独在终端下执行如下:
  1. gs_qunproxy_236_111:/data/gspace/server/other/pad_stat # /data/script/GetData -t 1 -d 2011-09-17 18:23:33 -i 2808 -a 97893|tail -3
  2. [color=Red]total:   2919 [/color]
  3. max value:       15
  4. min value:       0
  5. gs_qunproxy_236_111:/data/gspace/server/other/pad_stat # /data/script/GetData -t 1 -d 2011-09-16 18:23:54 -i 2808 -a 97893|tail -3
  6. [color=Red]total:   4198 [/color]
  7. max value:       17
  8. min value:       0
  9. gs_qunproxy_236_111:/data/gspace/server/other/pad_stat #
复制代码
4、疑问:
单独执行 两条命令的结果不一样:total的取值不一样
放在脚本里给变量赋值,两次传不同的日期执行脚本 得到的变量值居然一样?
没道理啊?
各位帮看看这个可能是什么原因导致赋值取到的结果一样?
thx~

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
2 [报告]
发表于 2011-10-13 07:29 |只看该作者
不清楚你的封装程序GetData, 感觉时间的参数有问题, 因为有空格,-d 后可能只接受了日期作参数,而忽略了后面的时间?能否改成这样,楼主手动运行一下是否成功?

/data/script/GetData -t 1 -d "2011-09-16 18:23:54" -i 2808 -a 97893

/data/script/GetData -t 1 -d "2011-09-17 18:23:33" -i 2808 -a 97893

相应的程序要改成:

DT=`date -d"$3 days ago" +'%F %T'`

/data/script/GetData -t 1 -d "$DT"  -i $1  -a $2|tac|awk -F":" '/total:/{print $2+0;exit}'

论坛徽章:
1
双子座
日期:2013-10-17 00:46:45
3 [报告]
发表于 2011-10-13 09:49 |只看该作者
回复 2# rdcwayx


    这个后面的时间是可选的,并不影响结果,呵呵。

gs_qunproxy_236_111:~ #  /data/script/GetData -t 1 -d 2011-10-13 18:23:33 -i 2808 -a 97893|tail -3 |head -1
total:   794
gs_qunproxy_236_111:~ # /data/script/GetData -t 1 -d 2011-10-12 -i 2808 -a 97893|tail -3 |head -1
total:   4100
gs_qunproxy_236_111:~ #

还是想不通为什么会有这么诡异的事情。。。

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
4 [报告]
发表于 2011-10-13 10:08 |只看该作者
本帖最后由 rdcwayx 于 2011-10-13 10:09 编辑

你有没有手动试过(带双引号):

/data/script/GetData -t 1 -d "2011-10-12 18:23:33" -i 2808 -a 97893

以及我后面给的修改? 要在程序里改的:

DT=`date -d"$3 days ago" +'%F %T'`

/data/script/GetData -t 1 -d "$DT"  -i $1  -a $2|tac|awk -F":" '/total:/{print $2+0;exit}'

论坛徽章:
1
双子座
日期:2013-10-17 00:46:45
5 [报告]
发表于 2011-10-13 10:46 |只看该作者
回复 4# rdcwayx


    一样的,引号有无,带不带时间都一样的。
算了,换个方法了。多谢。

论坛徽章:
0
6 [报告]
发表于 2012-12-12 10:59 |只看该作者
我也遇到差不多的问题,shell脚本的变量执行多少遍值都不变,必须在脚本的最开始初始化下一下变量,后面才能正确赋值
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP