So greifen Sie auf die IP-Adresse der ifconfig-Ausgabe zu


7

Es folgt meine ifconfig-Ausgabe

eth0      Link encap:Ethernet  
          UP BROADCAST MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)
          Interrupt:28 Base address:0x2000 

eth1      Link encap:Ethernet  
          inet addr:192.168.1.2  Bcast:192.168.1.255  Mask:255.255.255.0
      UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:36497 errors:0 dropped:0 overruns:0 frame:14515
          TX packets:44884 errors:1352 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:20781745 (20.7 MB)  TX bytes:17776225 (17.7 MB)
          Interrupt:17 Base address:0xc000 

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:16436  Metric:1
          RX packets:12 errors:0 dropped:0 overruns:0 frame:0
          TX packets:12 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:720 (720.0 B)  TX bytes:720 (720.0 B)

virbr0    Link encap:Ethernet  
          inet addr:192.168.122.1  Bcast:192.168.122.255  Mask:255.255.255.0

          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:24 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:0 (0.0 B)  TX bytes:4416 (4.4 KB)

vmnet1    Link encap:Ethernet 
          inet addr:192.168.185.1  Bcast:192.168.185.255  Mask:255.255.255.0

          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:24 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)

vmnet8    Link encap:Ethernet  
          inet addr:192.168.207.1  Bcast:192.168.207.255  Mask:255.255.255.0

          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:25 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)

Wie extrahiere ich mit grep die IP-Adresse jeder LAN-Karte?

Ist das möglich? Wie kann es erreicht werden?

Antworten:


15
$ ip -o addr show | awk '/inet/ {print $2, $3, $4}'
lo inet 127.0.0.1/8
lo inet6 ::1/128
eth0 inet 192.168.0.1/24
eth0 inet6 fe80::2a0:feed:dead:beef/64

2

Oh Mann, ich kann nicht widerstehen, meine Perl-Oneliner-Skriptfähigkeit zu verbessern, wenn ich einen Beitrag wie diesen sehe. Hier ist ein erster hackiger Versuch:

$ /sbin/ifconfig | \
perl -ane "(\$n)=(/^(\S+)/) and print \"\$n: \"; print (/addr:(\S+)/) and print \"\n\" if /inet/"
eth0: 192.168.0.11
lo: 127.0.0.1

Das könnte sehr verschärft werden, und es gibt viele Probleme, da es keine IPv6-Adressen usw. verarbeitet.


1

So mache ich es:

ETHERADD=$(/sbin/ifconfig |grep -e ^[a-z] |grep -v lo | awk '{ printf $1 FS}')

for i in $ETHERADD  
do
    IP=$(/sbin/ifconfig $i | grep -o '[0-9]*\.[0-9]*\.[0-9]*\.[0-9]*' | head -1)
    printf "%-16s%-42s*\n" "IP $i:"      "$IP"
done


1

Das benutze ich

#!/bin/bash
interfaces=$(/sbin/ifconfig |grep -e ^[a-z] |  awk '{ printf $1 " "}')
for i in $interfaces
do
    addr=$(/sbin/ifconfig $i | grep 'inet addr:' | cut -d: -f2 | awk '{ print $1}')
    addr6=$(/sbin/ifconfig $i | grep 'inet6 addr:' |sed 's/   *//g'| cut -d' ' -f3 | cut -d'/' -f1)
    echo "$i  inet4 $addr    inet6 $addr6"
done

0

Wie wäre es mit

ifconfig -a|awk '{print $1 " " $2}'|egrep -w 'Link|inet'|sed 's/ Link//'|sed 's/inet addr://'

Bei Ihrer Ausgabe kehrt das zurück

eth0
eth1
192.168.1.2
lo
127.0.0.1
virbr0
192.168.122.1
vmnet1
192.168.185.1
vmnet8
192.168.207.1

für mich.


0

Schrecklich hässlich und nur gut für IPv4:

ifconfig | egrep "^[a-z]|inet " | sed -e "s/ [ ]*Link.*/@/" -e "s/.*inet addr://" -e "s/ .*/#/" | tr -d '\012' | tr '@' ' ' | tr '#' '\012'


0

Ich bin mir nicht sicher, wie portabel dies ist, aber Sie können das gesamte sed / grep / awk / perl usw. mit dem hostnameBefehl und entweder -ioder -I(ich empfehle hostname -I) vermeiden :

   -i, --ip-address
          Display the network address(es) of the host name. Note that this works only if the host name can be resolved. Avoid using this option;  use  hostname
          --all-ip-addresses instead.

   -I, --all-ip-addresses
          Display all network addresses of the host. This option enumerates all configured addresses on all network interfaces. The loopback interface and IPv6
          link-local addresses are omitted. Contrary to option -i, this option does not depend on name resolution. Do not make any assumptions about the  order
          of the output.

Zum Beispiel:

[kbrandt@alpine: ~/] hostname -I
192.168.1.100 10.1.0.42 

Oh mein Schlechtes, du willst die Schnittstelle / IP-Kombination - mein Fehler.
Kyle Brandt

Kein Problem Kyle, ich habe etwas Neues gelernt, danke für deinen Vorschlag.
Registrierter Benutzer
Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.