首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >产生多个背景过程

产生多个背景过程
EN

Unix & Linux用户
提问于 2014-02-14 04:07:51
回答 1查看 1.2K关注 0票数 2

我有一个包含2,000,000行的文件。我正在为每一行运行一些命令。我试图使用GNU-parallelswift实现一些并行性,就像讨论的这里一样。然而,我从我的一个朋友那里得到了一个有趣的想法。

他建议在服务器中生成多个进程,因为服务器非常强大。我在想,如果我对每一行文件使用一个索引,我可以基于totallines mod number_of_processes生成多个进程。

例如,如果line_numbers为1,11和21,它将被发送到第一个进程,如果行号为2,12和22,则将发送到第二个进程,依此类推。

为了实现上述目标,我在shell脚本中经历了后台过程。在大多数教程/链接中,它们都会在命令中附加一个&,并告诉计算机将生成一个后台进程。我觉得很难理解这个概念。

EN

回答 1

Unix & Linux用户

发布于 2014-02-14 09:11:15

你的想法与GNU平行线的--管--循环--有什么不同?

代码语言:javascript
复制
seq 100 | parallel --pipe --round-robin -j10 -N 1 'echo Start;cat'

对GNU并行而言,逐行执行该操作有点效率低下。逐块地这样做是更有效的:

代码语言:javascript
复制
seq 1000000 | parallel --pipe --round-robin -j10 'echo Start;cat'

调整-阻塞以适应您的需要。

票数 2
EN
页面原文内容由Unix & Linux提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://unix.stackexchange.com/questions/115136

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档