繁体   English   中英

获取所有IP地址的Bash脚本

[英]Bash script to get all IP addresses

我正在尝试编写一个bash脚本来获取服务器上的所有IP地址。 该脚本应适用于所有主要发行版。 这是我有的:

ifconfig | grep 'inet addr:' | awk {'print $2'}

导致:

addr:10.1.2.3
addr:50.1.2.3
addr:127.0.0.1

我怎么能先删除addr:前缀? 第二,我如何排除127.0.0.1

ifconfigip淘汰了。 它还有标志-o ,写输出易于解析。 使用ip -4仅显示IPV4地址。 注意更简单的脚本,它已经排除了环回地址:

ip -o addr | awk '!/^[0-9]*: ?lo|link\/ether/ {print $2" "$4}'

或者如果您不想要网络:

ip -o addr | awk '!/^[0-9]*: ?lo|link\/ether/ {gsub("/", " "); print $2" "$4}'

没有必要grep 这是使用awk的一种方式:

仅列出地址:

ifconfig | awk -F "[: ]+" '/inet addr:/ { if ($4 != "127.0.0.1") print $4 }'

列出设备和地址:

ifconfig | awk -v RS="\n\n" '{ for (i=1; i<=NF; i++) if ($i == "inet" && $(i+1) ~ /^addr:/) address = substr($(i+1), 6); if (address != "127.0.0.1") printf "%s\t%s\n", $1, address }'

只需使用hostname您就可以使用-I标志获取所有IP地址的列表。

$ hostname --all-ip-addresses || hostname -I
10.10.85.100 10.20.85.100 10.30.85.100

$ hostname --ip-address || hostname -i
::1%1 127.0.0.1

Centos7(k3.10.0)

这是一个类似的脚本,我已经测试了获取ip范围的地址,但它很慢 - 有人可能会给出一个提示,如何加速这个? (这里的ip-range是获得所有线路的例子,这些线路似乎在温哥华和韩国之间):

#!/斌/庆典

for ip in {209..210}。{125..206}。{5..231}。{65..72}#any ip between 209.126.230.71 and 210.205.6.66

printf'===%s === \\ n'“$ ip”

whois“$ ip”>> /home/$user/test001.txt

DONE

如果这太简单或者在这里有些错误,只需回答或评论。

这个脚本将持续到大约5到8个小时。

这仅仅是几个先前答案和评论的精华。 样本输出包括在内。

要列出IP:

使用ip

(受限于IPv4和全球)

$ /sbin/ip -4 -o addr show scope global | awk '{gsub(/\/.*/,"",$4); print $4}'
192.168.82.134
138.225.11.92
138.225.11.2

使用ifconfig

(不包括127.0.0.1)

$ /sbin/ifconfig | awk -F "[: ]+" '/inet addr:/ { if ($4 != "127.0.0.1") print $4 }'
192.168.82.134
138.225.11.92
138.225.11.2

要将IP映射到主机名,请参阅此答案

使用grep -v忽略127.0.0.1

ifconfig | grep 'inet addr:' | awk {'print $2'} | grep -v '127.0.0.1'

使用sed编辑'addr:'

ifconfig | grep 'inet addr:' | awk {'print $2'}  | grep -v '127.0.0.1' | sed -e 's/addr://'

ifconfig | grep 'inet addr:' | awk {'print $2'} | awk 'BEGIN{FS=":"}{print $2}' | grep -v '127.0.0.1'

这是一个非常棘手的解决方案,但它有效:

ip a | awk ' !/[0-9]+\\: lo/ && /^[0-9]\\:/ || /inet / && !/127\\.0\\.0\\.1/ {print $2}'

输出:

eth0: 192.168.0.1/24

更好的是:

ip a | awk ' !/[0-9]+\\: lo/ && /^[0-9]\\:/ || /inet / && !/127\\.0\\.0\\.1/ {print $2}' | perl -i -pe "s/:\\n/: /g;" -pe "s/\\/[\\d]+$//"

输出:

eth0: 192.168.0.1

我没有一台机器有几个非环回接口,我可以检查它,随时发布你的发现。

如果它只是你要删除的“addr:”字,我会使用sed而不是像awk一样

ifconfig | grep 'inet addr:' | awk {'print $2'}| grep -v 127.0.0.1 | sed -e 's/addr://'

我总是惊讶地看到人们使用sed和awk而不是perl。

但首先,使用grep和awk以及额外的选项,可以随意:

ifconfig | grep 'inet addr:' | awk {'print $2'} | awk -F: {'print $2'} | grep -v '127.0.0.1'

用perl替换awks:

ifconfig | grep 'inet addr:' | perl -F\\s\|: -ane 'print "$F[2]\n"' | grep -v '127.0.0.1'

替换相同perl脚本中的greps:

ifconfig | perl -F\\s\|: -ane 'next if !/^inet addr:/ or /127\.0\.0\.1/; print "$F[2]\n"'

最后只是使用perl的正则表达式的力量:

ifconfig | perl -ne 'next if !/inet addr:(?<ip>[0-9.]+)/ or $+{ip} == "127.0.0.1"; print "$+{ip}\n"'

我将向您介绍一个名为OSQuery by Facebook的命令行工具,它可以帮助您通过类似SQL的查询来获取系统信息。 例如,对于你的情况,你会输入;

osquery> select * from interface_addresses; 

哪个会输出类似的东西;

interface = wlan0
       address = 192.168.0.101
          mask = 255.255.255.0
     broadcast = 192.168.0.255
point_to_point = 

我发现它更整洁方便。

ifconfig | grep 'inet addr:' | awk {'print $2'} | cut -d ":" -f 2

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM