相关疑难解决方法(0)

在许多服务器上通过 SSH 自动运行命令

.txt 文件中有一个 IP 地址列表,例如:

1.1.1.1
2.2.2.2
3.3.3.3
Run Code Online (Sandbox Code Playgroud)

每个 IP 地址后面都有一个服务器,并且在每个服务器上都有一个在端口 22 上运行的 sshd。并非每个服务器都在known_hosts列表中(在我的 PC 上,Ubuntu 10.04 LTS/bash)。

如何在这些服务器上运行命令并收集输出?

理想情况下,我想在所有服务器上并行运行这些命令。

我将在所有服务器上使用公钥身份验证。

以下是一些潜在的陷阱:

  • ssh 提示我将给定的服务器 ssh 密钥放入我的known_hosts文件中。
  • 给定的命令可能返回非零退出代码,表明输出可能无效。我需要认识到这一点。
  • 与给定服务器的连接可能无法建立,例如由于网络错误。
  • 应该有一个超时,以防命令运行的时间比预期的要长,或者服务器在运行命令时出现故障。

服务器是 AIX/ksh(但我认为这并不重要。

scripting ssh parallelism

55
推荐指数
5
解决办法
22万
查看次数

对匹配模式的多个文件并行执行命令

假设我有一个命令接受一个文件路径参数:

mycommand myfile.txt
Run Code Online (Sandbox Code Playgroud)

现在我想对多个文件并行执行此命令,更具体地说,文件匹配 pattern myfile*

有没有简单的方法来实现这一目标?

command-line parallelism

2
推荐指数
2
解决办法
3124
查看次数

标签 统计

parallelism ×2

command-line ×1

scripting ×1

ssh ×1