ping 和 awk 给 ping 结果打上 timestamp,但是管道总是卡住的感觉

2015-12-03 16:43:48 +08:00
 pythonee
就是想实现 ping 的返回结果加上时间戳,输出到 terminal 和写入日志,首先反应就是下面的脚本

ping www.baidu.com -i 2 | awk '{print strftime("%Y-%m-%d %H:%M:%S")"|"$0}'|tee -a ping.log

但是这样执行总在开始时卡住,但是不是很明白为什么会卡住,如果把 ping 换成别的命令,就不会有这个问题,怀疑是 ping 的问题,然后 stackoverflow 启示了下,改成下面的脚本

ping www.baidu.com -i 1 | while read pong; do echo "$(date +"%Y-%m-%d %H:%M:%S") | $pong"; done | tee -a ping.log

这样就执行的非常好,还是第一次这么使用$pong ,这是为什么呢, ping 跟管道配合的不太好吗
3330 次点击
所在节点    Linux
7 条回复
dant
2015-12-03 16:54:34 +08:00
flush
octopus_new
2015-12-03 17:02:25 +08:00
awk 执行是在针对输出结果操作,你的 ping 并没有结束,所以 awk 一直都不会被执行,看上去‘死掉了’。实际上你给 ping 加一个 ’-c 次数‘ 参数之后你的命令就可以执行了。
octopus_new
2015-12-03 17:04:37 +08:00
针对我以上说的,虽然执行了,但是结果可能不是你想要的,因为 awk 只是针对结果操作,而不是实时对 ping 进行打标签操作。
Arthur2e5
2015-12-09 02:41:56 +08:00
缓冲区要绕过有一些 hack 的程序的,例如系统多半自带的 stdbuf : https://www.gnu.org/software/coreutils/manual/html_node/stdbuf-invocation.html

@octopus_new 什么啊,明明是输入输出缓冲区的锅子……

@dant bingo
pythonee
2015-12-09 10:22:24 +08:00
@octopus_new 其实我当时也是这么想的,但是加了-c 并没有什么用
pythonee
2015-12-09 10:22:40 +08:00
@Arthur2e5 用了$pong 就好使了,这是为啥咧
Arthur2e5
2015-12-10 09:48:16 +08:00
@pythonee 1. 你没看清本质,本质是 read 2. 因为 shell read 和 echo 就是这样行缓冲玩的。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/240904

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX