我有一个名为“ips”的文件,其中包含我需要ping的所有ips。为了ping这些IP,我使用以下代码:
cat ips|xargs ping -c 2
但是控制台告诉我ping的用法,我不知道如何正确地做到这一点。我正在使用Mac os
答案 0 :(得分:13)
由于-n1
不支持多个IP,您需要使用xargs
选项与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
答案 1 :(得分:2)
在ips
文件的每一行中使用ip或hostname:
( while read ip; do ping -c 2 $ip; done ) < ips
您还可以使用-W
标志更改超时,因此如果某些主机没有,则不会锁定您的脚本太长时间。在这种情况下,安静输出-q
也很有用。
( while read ip; do ping -c1 -W1 -q $ip; done ) < ips
答案 2 :(得分:1)
如果文件每行1个ip(并且它不是太大),你可以使用for循环:
for ip in $(cat ips); do
ping -c 2 $ip;
done
答案 3 :(得分:1)
你可以使用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
...
答案 4 :(得分:1)
使用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
答案 5 :(得分:0)
尝试这样做:
cat ips | xargs -i% ping -c 2 %
答案 6 :(得分:0)
正如@Lupus所建议的,你可以使用“fping”,但是输出并不是人类友好的 - 它会在几秒钟内滚出你的屏幕,让你无法看到正在发生的事情。为了解决这个问题,我刚刚发布了ping-xray。我试图在ascii终端下使其尽可能直观,并且它为所有目标创建具有精确毫秒分辨率的CSV日志。
希望你会发现它有用。