我有一个名为“ips”的文件,其中包含我需要 ping 的所有 ip。为了 ping 这些 IP,我使用以下代码:
cat ips|xargs ping -c 2
但是控制台向我显示了 ping 的用法,我不知道如何正确执行。我正在使用 Mac 操作系统
您需要使用选项-n1
withxargs
一次传递一个 IP,因为ping
不支持多个 IP:
$ cat ips | xargs -n1 ping -c 2
演示:
$ cat ips
127.0.0.1
google.com
bbc.co.uk
$ cat ips | xargs echo ping -c 2
ping -c 2 127.0.0.1 google.com bbc.co.uk
$ cat ips | xargs -n1 echo ping -c 2
ping -c 2 127.0.0.1
ping -c 2 google.com
ping -c 2 bbc.co.uk
# Drop the UUOC and redirect the input
$ xargs -n1 echo ping -c 2 < ips
ping -c 2 127.0.0.1
ping -c 2 google.com
ping -c 2 bbc.co.uk
在文件的每一行中使用 ip 或主机名ips
:
( while read ip; do ping -c 2 $ip; done ) < ips
您还可以使用-W
标志更改超时,因此如果某些主机未启动,它不会锁定您的脚本太长时间。在-q
这种情况下,对于安静的输出也很有用。
( while read ip; do ping -c1 -W1 -q $ip; done ) < ips
如果文件是每行 1 个 ip(并且不是太大),您可以使用 for 循环来完成:
for ip in $(cat ips); do
ping -c 2 $ip;
done
你可以使用fping。它也可以并行执行,并具有脚本友好的输出。
$ cat ips | xargs fping -q -C 3
10.xx.xx.xx : 201.39 203.62 200.77
10.xx.xx.xx : 288.10 287.25 288.02
10.xx.xx.xx : 187.62 187.86 188.69
...
使用 GNU Parallel,您可以:
parallel -j0 ping -c 2 {} :::: ips
这将并行运行与您拥有的 ips 或进程一样多的作业。
它还确保不同作业的输出不会混合在一起,因此如果您使用输出,则可以保证不会从两个不同的作业中得到半行。
GNU Parallel 是一个通用的并行器,可以轻松地在同一台机器上或在您可以通过 ssh 访问的多台机器上并行运行作业。
如果您想在 4 个 CPU 上运行 32 个不同的作业,那么并行化的直接方法是在每个 CPU 上运行 8 个作业:
GNU Parallel 会在完成后生成一个新进程 - 保持 CPU 处于活动状态,从而节省时间:
安装
如果没有为您的发行版打包 GNU Parallel,您可以进行个人安装,这不需要 root 访问权限。这样做可以在 10 秒内完成:
(wget -O - pi.dk/3 || curl pi.dk/3/ || fetch -o - http://pi.dk/3) | bash
有关其他安装选项,请参阅http://git.savannah.gnu.org/cgit/parallel.git/tree/README
学到更多
查看更多示例:http ://www.gnu.org/software/parallel/man.html
观看介绍视频:https ://www.youtube.com/playlist?list=PL284C9FF2488BC6D1
浏览教程:http ://www.gnu.org/software/parallel/parallel_tutorial.html
注册电子邮件列表以获得支持:https ://lists.gnu.org/mailman/listinfo/parallel
尝试这样做:
cat ips | xargs -i% ping -c 2 %
正如@Lupus 所建议的那样,您可以使用“fping”,但输出对人类不友好 - 它会在几秒钟内滚动出您的屏幕,让您不知道发生了什么。为了解决这个问题,我刚刚发布了 ping-xray。我试图在 ascii 终端下使其尽可能可视化,并且它会为所有目标创建具有精确毫秒分辨率的 CSV 日志。
希望你会发现它有帮助。