小心grep 的buffer
浏览:3017次 出处信息
在统计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的区别是什么? (阅读:6838)
- Linux grep命令用法 (阅读:6002)
- Linux操作系统中内存buffer和cache的区别 (阅读:5316)
- grep 正则表达式选项要记得转义 (阅读:5093)
- 快速预热Innodb Buffer Pool的方法 (阅读:3980)
- 学习Grep,Sed中的正则 (阅读:3910)
- MySQL数据库InnoDB存储引擎 Buffer pool LRU List Flush策略详解 (阅读:3791)
- MySQL数据库InnoDB存储引擎 Insert Buffer实现机制详解 (阅读:3534)
- grep: writing output: Broken pipe in iTerm2 (阅读:3493)
- InnoDB之Dirty Page、Redo log (阅读:3434)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:配置 syslog-ng 的服务器简介
后一篇:tcpdump匹配http头 >>
文章信息
- 作者:phpor <lijunjie1982@yahoo.com.cn> 来源: PHPor 的blog
- 标签: buffer grep
- 发布时间:2012-01-24 14:01:13
建议继续学习
近3天十大热文
- [54] IOS安全–浅谈关于IOS加固的几种方法
- [52] android 开发入门
- [52] 如何拿下简短的域名
- [51] 图书馆的世界纪录
- [49] Oracle MTS模式下 进程地址与会话信
- [49] Go Reflect 性能
- [47] 【社会化设计】自我(self)部分――欢迎区
- [46] 读书笔记-壹百度:百度十年千倍的29条法则
- [36] 程序员技术练级攻略
- [29] 视觉调整-设计师 vs. 逻辑