web-dev-qa-db-ja.com

シェルスクリプトを使用してIPアドレスを取得する方法

シェルスクリプトを使用してIPアドレスを取得したい。特定のIPアドレスを取得する方法をeth0、eth1、またはeth2を知らずに。

Localhostアドレスを取得する必要はありません。取得したいのはプライベートIPアドレスです。

44
Beginner

名前に関係なく、すべてのIPアドレスをリストするには、次のことを試してください。

ifconfig | Perl -nle 's/dr:(\S+)/print $1/e'

または:

ifconfig | awk '/inet addr/{print substr($2,6)}'

特定のインターフェースのIPのみが必要な場合は、ifconfigの直後にインターフェース名(例:eth0)を指定します。

ifconfig eth0 | Perl -nle 's/dr:(\S+)/print $1/e'

または:

ifconfig eth0 | awk '/inet addr/{print substr($2,6)}'
40
cuonglm

できるよ :

_ip addr | grep 'state UP' -A2 | tail -n1 | awk '{print $2}' | cut -f1 -d'/'_

_ip addr_にリストされている最初のプライベートIPアドレスを取得します。

たとえば、_ip addr_を使用すると、次のようになります。

_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
_

以前のコマンドラインでは、_192.168.0.85_のIPアドレスである_em1_を取得します。

シェルスクリプト内の変数に入れるには、var=$(ip addr | grep 'state UP' -A2 | tail -n1 | awk '{print $2}' | cut -f1 -d'/')を実行します。これで、スクリプトの最後まで、_$var_にIPアドレスの値が設定されます。

63
lgeorget

stackoverflow からのコピーの貼り付けは、サイト間での複製ができないためです。 bashでもshでもないことは知っていますが、pythonがこの時点でインストールされていないのは誰ですか?

netifaces を使用する必要があります。 Mac OS X、Linux、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'

プロトコルのインデックスに使用される番号は/usr/include/linux/socket.h(Linuxの場合)...

#define AF_INET         2       /* Internet IP Protocol         */
#define AF_INET6        10      /* IP version 6                 */
#define AF_PACKET       17      /* Packet family                */

コピーの貼り付けを終了します

必要なのがアップおよびアウトバウンドインターフェースのIPのみである場合、 this が機能します。

しかし、あなたが望むものを正確に理解することができないように見えるので、インターフェース全体を列挙したい場合は、別のオプションがあります:

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
11
RobotHumans