linux-对每个主机使用自定义参数的并行SSH

关于并行ssh有很多线程和文档,但是在将自定义参数传递给每个主机时我找不到任何东西.以pssh为例,将hosts文件定义为:

111.111.111.111
222.222.222.222

但是,我想通过shell脚本将自定义参数传递给每个主机,如下所示:

111.111.111.111 param1a param1b ...
222.222.222.222 param2a param2b ...

或者,更好的是,主机和参数将分为两个文件.

因为这种情况不常见,是否会滥用并行ssh?我应该从脚本中创建许多ssh进程吗?我应该如何处理?

解决方法:

您可以使用GNU parallel.

假设您有一个文件argfile:

111.111.111.111 param1a param1b ...
222.222.222.222 param2a param2b ...

然后跑步

parallel --colsep ' ' ssh {1} prog {2} {3} ... :::: argfile

将在具有相应参数的每个主机上运行prog.每个主机的参数数量必须相同,这一点很重要.

上一篇:连接到dask.distributed群集时出现Pickle错误


下一篇:Python:使用pyzmq进行集中记录