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

linux – 从管道读取数据并写入标准输出,中间延迟.必须处理二进制文件

我现在已经尝试了大约一个小时来找到解决这个问题的优雅方案.我的目标基本上是编写带宽控制管道命令,我可以在各种情况下重复使用(不仅仅是网络传输,我知道scp -l 1234).我想做的是:

>延迟X秒.
>从管道读取Y量(或者如果没有足够的话,小于Y).
>将读取数据写入标准输出.

哪里:

> X可以是1..n.
> Y可以是1个字节,直到某个高值.

我的问题是:

>它必须支持Bash无法很好处理的二进制数据.

我采取或至少考虑过的道路:

>使用while read数据结构,它会过滤您使用的编码中的所有白色字符.
>使用dd bs = 1 count = 1并循环. dd似乎没有不同的退出代码,当有和没有东西时.这使得更难知道何时停止循环.如果我将标准错误重定向到临时文件,读取它以检查某些内容是否已转移(如在stderr上打印的统计信息中)并重复,则此方法应该有效.但是我怀疑如果在大量数据上使用它会非常慢,如果有可能我想跳过创建任何临时文件.

关于如何使用Bash尽可能干净地解决这个问题的任何想法或建议?

解决方法:

它不是很优雅,但您可以使用一些重定向技巧来捕获由dd复制的字节数,然后将其用作while循环的退出条件:

while [ -z "$byte_copied" ] || [ "$byte_copied" -ne 0 ]; do 
    sleep $X; 
    byte_copied=$(dd bs=$Y count=1 2>&1 >&4 | awk '$2 == "byte"{print $1}'); 
done 4>&1

但是,如果您的意图是限制传输吞吐量,我建议您使用光伏.

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

相关推荐