小心grep 的buffer
浏览:3145次 出处信息
在统计mysql查询次数时,有如下命令:
while :; do sleep 1; mysql -u user -ppass -h phpor.net -P 3306 -e 'show status like "Questions";'; done |grep Ques | awk '{print $2 - old; old = $2; }'
几秒钟后都看不到结果,怀疑是awk的buffer造成的,于是改写为:
while :; do sleep 1; mysql -u user -ppass -h phpor.net -P 3306 -e 'show status like "Questions";'; done |grep Ques | awk '{print $2 - old; old = $2; fflush();}'
依然不行,于是,把该命令推到后台,使用strace跟踪了一下awk,发现awk没有读到内容,很自然地,跟踪grep吧,发现grep read到内容了,但是总是不write,开始怀疑我的 Ques写错了,仔细比对,也没有问题呀,突然,屏幕上打印出了很多信息,于是,我恍然大悟,应该是grep的buffer搞的鬼,于是man了一下grep,果然有这方面的选项,再次修改如下:
while :; do sleep 1; mysql -u user -ppass -h phpor.net -P 3306 -e 'show status like "Questions";'; done |grep --line-buffered Ques | awk '{print $2 - old; old = $2; fflush();}'
终于OK了
while :; do sleep 1; mysql -u user -ppass -h phpor.net -P 3306 -e 'show status like "Questions";'; done |grep Ques | awk '{print $2 - old; old = $2; }'
几秒钟后都看不到结果,怀疑是awk的buffer造成的,于是改写为:
while :; do sleep 1; mysql -u user -ppass -h phpor.net -P 3306 -e 'show status like "Questions";'; done |grep Ques | awk '{print $2 - old; old = $2; fflush();}'
依然不行,于是,把该命令推到后台,使用strace跟踪了一下awk,发现awk没有读到内容,很自然地,跟踪grep吧,发现grep read到内容了,但是总是不write,开始怀疑我的 Ques写错了,仔细比对,也没有问题呀,突然,屏幕上打印出了很多信息,于是,我恍然大悟,应该是grep的buffer搞的鬼,于是man了一下grep,果然有这方面的选项,再次修改如下:
while :; do sleep 1; mysql -u user -ppass -h phpor.net -P 3306 -e 'show status like "Questions";'; done |grep --line-buffered Ques | awk '{print $2 - old; old = $2; fflush();}'
终于OK了
建议继续学习:
- Buffer和cache的区别是什么? (阅读:6902)
- Linux grep命令用法 (阅读:6149)
- Linux操作系统中内存buffer和cache的区别 (阅读:5371)
- grep 正则表达式选项要记得转义 (阅读:5296)
- 快速预热Innodb Buffer Pool的方法 (阅读:4088)
- 学习Grep,Sed中的正则 (阅读:4030)
- MySQL数据库InnoDB存储引擎 Buffer pool LRU List Flush策略详解 (阅读:3906)
- MySQL数据库InnoDB存储引擎 Insert Buffer实现机制详解 (阅读:3682)
- grep: writing output: Broken pipe in iTerm2 (阅读:3619)
- InnoDB之Dirty Page、Redo log (阅读:3559)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:配置 syslog-ng 的服务器简介
后一篇:tcpdump匹配http头 >>
文章信息
- 作者:phpor <lijunjie1982@yahoo.com.cn> 来源: PHPor 的blog
- 标签: buffer grep
- 发布时间:2012-01-24 14:01:13
建议继续学习
近3天十大热文
-
[63] memory prefetch浅析
-
[57] find命令的一点注意事项
-
[32] 基本排序算法的PHP实现
-
[32] Oracle bbed工具的编译
-
[31] 读书笔记-壹百度:百度十年千倍的29条法则
-
[30] 卡诺模型―设计品质与设计价值的思考
-
[25] 程序员技术练级攻略
-
[24] 8大实用又重要Mac使用技巧
-
[23] 小屏幕移动设备网页设计注意事项
-
[21] 杨建:网站加速--Cache为王篇