用于从IPv6地址中查找网络接口名称的脚本

时间:2016-09-16 20:27:49

标签: bash shell ipv6

专家,

请帮我编写一个脚本,以便从给定的IPv6地址中找到网络接口名称。

例如:

if "ifconfig" gives the output like:

lo        Link encap:Local Loopback
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:65536  Metric:1
          RX packets:90440 errors:0 dropped:0 overruns:0 frame:0
          TX packets:90440 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:10181289 (10.1 MB)  TX bytes:10181289 (10.1 MB)

eth0      Link encap:Ethernet  HWaddr 00:50:56:bb:9f:9d
          inet6 addr: fe80::250:56ff:febb:9f9d/64 Scope:Link
          inet6 addr: 2001:111:1111:1111:1000::41/64 Scope:Global
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:138859 errors:0 dropped:10 overruns:0 frame:0
          TX packets:69332 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:46310896 (46.3 MB)  TX bytes:18119186 (18.1 MB)

eth1      Link encap:Ethernet  HWaddr 00:50:56:bb:9f:9d
          inet6 addr: fe80::250:56ff:febb:9f9d/64 Scope:Link
          inet6 addr: 2001:222:2222:2222:1000::41/64 Scope:Global
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:138859 errors:0 dropped:10 overruns:0 frame:0
          TX packets:69332 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:46310896 (46.3 MB)  TX bytes:18119186 (18.1 MB)

,给定的IPv6地址是:2001:111:1111:1111:1000 :: 41 那么输出应该是“eth0”

提前感谢您的帮助。

感谢。

1 个答案:

答案 0 :(得分:0)

为什么让事情复杂化?我喜欢简单。这就像它得到的一样简单。 (并且您不应该在现代Linux发行版上使用ifconfig,因为它是deprecatednot installed by default。)

ip a s to fda8:75f3:eca7:100::1 | awk -F ": " 'NF > 1 {print $2}'

让我们一步一步地讨论它。

首先是ip输出。

$ ip address show to fda8:75f3:eca7:100::1
12: virbr2: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000
    inet6 fda8:75f3:eca7:100::1/64 scope global 
       valid_lft forever preferred_lft forever

这告诉我们IP所在的接口,并省略了接口上可能存在的任何其他地址。

因此我们将使用awk解析它。我们使用": "作为field separator,打印第二个字段,然后only print matching lines

$ ip address show to fda8:75f3:eca7:100::1 | awk -F ": " 'NF > 1 {print $2}'
virbr2

最后,我们会将address show缩写为最小值。

$ ip a s to fda8:75f3:eca7:100::1 | awk -F ": " 'NF > 1 {print $2}'
virbr2

如果您想找到其中一个地址,这也适用于IPv4地址。