当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 5 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : 这到底有什么区别?只是加法前后位置调换,就报错?为什么?
帖子发表于 : 2018-05-01 12:22 

注册: 2017-09-21 14:46
帖子: 28
系统: ubuntu16.04
送出感谢: 5
接收感谢: 0 次
环境:CentOS release 6.9 (Final) 2.6.32-696.10.1.el6.x86_64
bash:GNU bash, version 4.1.2(2)-release (x86_64-redhat-linux-gnu)

需求是统计niginx的access.log的总流量
脚本1正常
代码:
sum=0
while read line
        do
                SIZE=`echo $line|awk '{print $10}'|egrep -v "^\""`
                expr $SIZE + 1 &>/dev/null
                [ $? -eq 0 ]&&{
                #echo $SIZE
                sum=$(($SIZE+$sum))
                }
        done<./access.log
echo $sum


脚本2就不行
代码:
sum=0
while read line
        do
                SIZE=`echo $line|awk '{print $10}'|egrep -v "^\""`
                expr $SIZE + 1 &>/dev/null
                [ $? -eq 0 ]&&{
                #echo $SIZE
                sum=$(($sum+$SIZE))
                }
        done<./access.log
echo $sum


这两个脚本的区别就是sum=$(($sum+$SIZE)) sum=$(($SIZE+$sum)) 两个变量谁在前 谁在后

调试脚本2时 卡在这个地方
代码:
+ read line
++ egrep -v '^"'
++ awk '{print $10}'
++ echo 1.12.77.113 - - '[18/Apr/2018:10:22:50' '+0800]' '"GET' / 'HTTP/1.1"' 200 57700 '"http://39.105.19.97/?page_id=10"' '"Mozilla/5.0' '(Windows' NT '10.0;' 'Win64;' 'x64)' AppleWebKit/537.36 '(KHTML,' like 'Gecko)' Chrome/65.0.3325.181 'Safari/537.36"'
+ SIZE=57700
+ expr 57700 + 1
+ '[' 0 -eq 0 ']'
+ sum=31596953
+ read line
++ egrep -v '^"'
++ awk '{print $10}'
++ echo 1.12.77.113 - - '[18/Apr/2018:10:27:28' '+0800]' '"x03"' 400 174 '"-"' '"-"'
+ SIZE=
+ expr + 1
+ '[' 0 -eq 0 ']'
access.sh: line 8: 31596953+: syntax error: operand expected (error token is "+")
[root@bbs logs]#


附带日志 脑袋很疼


附件:
access.txt [702.44 KiB]
还未被下载
页首
 用户资料  
 
2 楼 
 文章标题 : Re: 这到底有什么区别?只是加法前后位置调换,就报错?为什么?
帖子发表于 : 2018-05-01 14:41 
头像

注册: 2009-04-11 23:46
帖子: 4164
系统: Arch Linux
送出感谢: 11
接收感谢: 127
数学表达式里边的变量名不要加 $。
建议脚本写好之后使用 shellcheck 检查一下。


_________________
我的博客 https://blog.lilydjwg.me/
提问的智慧 害人的 X-Y 问题
Arch Linux 中文论坛

我的vimrc: https://git.io/vimrc



_________________
评价: 3.7% kidkey
 
页首
 用户资料  
 
3 楼 
 文章标题 : Re: 这到底有什么区别?只是加法前后位置调换,就报错?为什么?
帖子发表于 : 2018-05-01 16:44 

注册: 2017-09-21 14:46
帖子: 28
系统: ubuntu16.04
送出感谢: 5
接收感谢: 0 次
lilydjwg 写道:
数学表达式里边的变量名不要加 $。
建议脚本写好之后使用 shellcheck 检查一下。


:em11


页首
 用户资料  
 
4 楼 
 文章标题 : Re: 这到底有什么区别?只是加法前后位置调换,就报错?为什么?
帖子发表于 : 2018-05-01 19:57 

注册: 2017-09-21 14:46
帖子: 28
系统: ubuntu16.04
送出感谢: 5
接收感谢: 0 次
这神器好是好 就是有点太严谨了 :em06


页首
 用户资料  
 
5 楼 
 文章标题 : Re: 这到底有什么区别?只是加法前后位置调换,就报错?为什么?
帖子发表于 : 2018-05-01 20:06 
头像

注册: 2009-04-11 23:46
帖子: 4164
系统: Arch Linux
送出感谢: 11
接收感谢: 127
kidkey 写道:
这神器好是好 就是有点太严谨了 :em06

习惯了就好 :-)


_________________
我的博客 https://blog.lilydjwg.me/
提问的智慧 害人的 X-Y 问题
Arch Linux 中文论坛

我的vimrc: https://git.io/vimrc


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 5 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 4 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译