微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

linux – 在管道中杀死上一个命令

我正在运行这样的模拟

./waf --run scratch/myfile | awk -f filter.awk 

如果filter.awk检测到发生了某些事情(例如在读取特定行之后),我怎么能杀死waf命令?

我不能改变waf或myfile.我只能更改filter.awk和上面的命令(显然).

评论后更新:

> waf在收到SIGPIPE后没有终止(因为它应该?)
>它产生了需要清理的子进程.

这是my own answer(和挑战).

在研究了@theotherguy的ans @ Chris的答案后,我简化了一下并得到了这个:

tmp=$(mktemp)
{ ./waf --run scratch/myfile & echo $! > "$tmp"; } | { awk -f filter.awk; pkill -P $(<$tmp); kill $(<$tmp); }

不幸的是我无法摆脱tmp文件,每次尝试将PID作为变量传递失败.

我不会改变已接受的答案(因为它是真正需要时才有效的答案),但对于任何可以简化更多的人来说都是1.

解决方法:

是什么让这个棘手的是,当管道断裂时,waf行为不当,它产生了第二个过程,我们也必须摆脱它:

tmp=$(mktemp)
cat <(./waf --run scratch/myfile & echo $! > "$tmp"; wait) | awk -f filter.awk; 
pkill -P $(<$tmp)
kill $(<$tmp)

>我们使用<(进程替换)在后台运行waf并将其pid写入临时文件.
>我们使用cat作为中介来将数据从此进程中继到awk,因为cat会在管道损坏时正常退出,从而允许管道完成.
>管道完成后,我们会杀死所有已生成的进程(通过父PID)
>最后我们杀了waf本身.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐