系统:Linux 4.13.0-43-generic #48~16.04.1-Ubuntu BASH_VERSION='4.3.48(1)-release'
命令:
while sleep 5
do
date +%T
done | awk -F: '{print $3}'
应该打印“日期”输出的第三个字段(秒),每 5 秒一行。问题:awk 仅在管道缓冲区已满时才从管道读取并处理其输入。即当生成超过 4K 的输入时。
当awk被cat替换时,按预期每 5 秒打印一行。
这个代码片段是从一个在其他系统上运行良好的 shell 脚本简化而来的,所以在这个系统中一定有一些关于 bash、awk 及其配置的东西。
简而言之,有没有办法让awk在从管道中读取时表现得像猫一样?
@Ed Morton:我确实尝试在每次打印后添加fflush(),但它不起作用——这表明问题出在 awk 的输入上,而不是输出上。我还尝试添加对system("date")的调用,这表明 awk 确实一次获取所有输入行,而不是在它们生成时立即获取。
对于那些问:
$ awk -W version
mawk 1.3.3 Nov 1996, Copyright (C) Michael D. Brennan
compiled limits:
max NF 32767
sprintf buffer 2040