linux – 从管道读取数据并写入标准输出,中间延迟.必须处理二进制文件
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了linux – 从管道读取数据并写入标准输出,中间延迟.必须处理二进制文件,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1102字,纯文字阅读大概需要2分钟。
内容图文
![linux – 从管道读取数据并写入标准输出,中间延迟.必须处理二进制文件](/upload/InfoBanner/zyjiaocheng/955/0f1e3184e58747e3b5f9f46a647c3b01.jpg)
我现在已经尝试了大约一个小时来找到解决这个问题的优雅方案.我的目标基本上是编写带宽控制管道命令,我可以在各种情况下重复使用(不仅仅是网络传输,我知道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
但是,如果您的意图是限制传输吞吐量,我建议您使用光伏.
内容总结
以上是互联网集市为您收集整理的linux – 从管道读取数据并写入标准输出,中间延迟.必须处理二进制文件全部内容,希望文章能够帮你解决linux – 从管道读取数据并写入标准输出,中间延迟.必须处理二进制文件所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。