シェルスクリプトを使用してIPアドレスを取得したい。特定のIPアドレスを取得する方法をeth0、eth1、またはeth2を知らずに。
Localhostアドレスを取得する必要はありません。取得したいのはプライベートIPアドレスです。
名前に関係なく、すべての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)}'
できるよ :
_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アドレスの値が設定されます。
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