最近寫背景業務邏輯,要用到擷取本機ip位址的方法,記錄兩個python的實作方式:
import socket
import struct
import fcntl
import commands
def getLocalIP():
status,output=commands.getstatusoutput("hostname -i")
if status :
return '127.0.0.1'
else :
return output
def getip(ethname):
s=socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
return socket.inet_ntoa(fcntl.ioctl(s.fileno(), 0X8915, struct.pack('256s', ethname[:15]))[20:24])
if __name__=='__main__':
print "getip :" , getip('eth0')
print "getLocalIP :", getLocalIP()
注意 本案例中 我寫的是 eth0 , 如果是生産環境做了網卡綁定的話 需要使用 getip(bond0)
執行結果
[yangyidba@rac3 10:31:12 ~]
$ python getip.py
getip : 10.10.15.12
getLocalIP : 10.10.15.12
還有shell 的實作方式, 可以使用 以下shell 方式 替代python 實作中的 hostname -i :
host `hostname --fqdn` 2>/dev/null | awk '{print $NF}'
10.10.15.12
ifconfig -a|grep inet|grep -v 127.0.0.1|grep -v inet6|awk '{print $2}'|tr -d "addr:"
ifconfig|grep -v "127.0.0.1" | sed -n '/inet addr/s/^[^:]*:\([0-9.]\{7,15\}\) .*/\1/p'