关于并行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.每个主机的参数数量必须相同,这一点很重要.