Se você quiser listar todos os endereços IP, independentemente do nome, tente o seguinte:
ifconfig | perl -nle 's/dr:(\S+)/print $1/e'
ou:
ifconfig | awk '/inet addr/{print substr($2,6)}'
Deseja obter o endereço IP usando o script Shell. Sem conhecer a eth0 ou eth1 ou eth2 Como obter o endereço IP específico.
Não tenho interesse em obter o endereço do host local, quero obter endereço IP privado .
Você pode fazer:
ip addr | grep 'state UP' -A2 | tail -n1 | awk '{print $2}' | cut -f1 -d'/'
que fornece o primeiro endereço IP privado listado em ip addr
.
Por exemplo, com ip addr
, obtenho:
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: em1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
link/ether 00:16:76:de:c1:f1 brd ff:ff:ff:ff:ff:ff
inet 192.168.0.85/24 brd 192.168.0.255 scope global dynamic em1
valid_lft 42505sec preferred_lft 42505sec
inet6 fe80::216:76ff:fede:c1f1/64 scope link
valid_lft forever preferred_lft forever
3: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default
link/ether 52:54:00:da:92:d0 brd ff:ff:ff:ff:ff:ff
inet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0
valid_lft forever preferred_lft forever
4: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc pfifo_fast master virbr0 state DOWN group default qlen 500
link/ether 52:54:00:da:92:d0 brd ff:ff:ff:ff:ff:ff
Com a linha de comando anterior, recebo 192.168.0.85
, que é o endereço IP de em1
.
Para colocá-lo em uma variável dentro de um script de shell, você pode fazer var=$(ip addr | grep 'state UP' -A2 | tail -n1 | awk '{print $2}' | cut -f1 -d'/')
. Agora, até o final do script, $var
terá o valor do endereço IP.
Colar de cópia flagrante de stackoverflow , pois não podemos enganar os sites. Eu sei que não é bash ou sh, mas quem não tem python instalado neste momento?
Você deve usar redes . Ele foi projetado para ser compatível com várias plataformas no Mac OS X, Linux e Windows.
>>> import netifaces as ni
>>> ni.interfaces()
['lo', 'eth0', 'eth1', 'vboxnet0', 'dummy1']
>>> ni.ifaddresses('eth0')
{17: [{'broadcast': 'ff:ff:ff:ff:ff:ff', 'addr': '00:02:55:7b:b2:f6'}], 2: [{'broadcast': '24.19.161.7', 'netmask': '255.255.255.248', 'addr': '24.19.161.6'}], 10: [{'netmask': 'ffff:ffff:ffff:ffff::', 'addr': 'fe80::202:55ff:fe7b:b2f6%eth0'}]}
>>>
>>> ni.ifaddresses.__doc__
'Obtain information about the specified network interface.\n\nReturns a dict whose keys are equal to the address family constants,\ne.g. netifaces.AF_INET, and whose values are a list of addresses in\nthat family that are attached to the network interface.'
>>> # for the IPv4 address of eth0
>>> ni.ifaddresses('eth0')[2][0]['addr']
'24.19.161.6'
Os números usados para indexar protocolos são de /usr/include/linux/socket.h
(no Linux) ...
#define AF_INET 2 /* Internet IP Protocol */
#define AF_INET6 10 /* IP version 6 */
#define AF_PACKET 17 /* Packet family */
Copiar cópia final
Se tudo o que você quer é o IP da interface de saída e saída, isso funciona.
Ainda é outra opção se você quiser apenas enumerar as interfaces acima, já que ninguém parece ser capaz de entender exatamente o que você quer:
import netifaces as ni
ints = ni.interfaces()
for i in ints:
if 'eth' in i:
try:
ni.ifaddresses(i)[2][0]['addr']
print("interface: " + i)
print("address: " + ni.ifaddresses(i)[2][0]['addr'])
except:
pass
elif 'wlan' in i:
try:
ni.ifaddresses(i)[2][0]['addr']
print("interface: " + i)
print("address: " + ni.ifaddresses(i)[2][0]['addr'])
except:
pass