获取当前IP地址的shell脚本详解
ifconfig返回的信息中包括IP地址,但要在Shell中获取当前IP地址,则要麻烦一些。
获取方法
由于不同系统中ifconfig返回信息的格式有一定差别,故分开讨论:[1]
一、Linux:
LC_ALL=C ifconfig | grep 'inet addr:'| grep -v '127.0.0.1' |
cut -d: -f2 | awk '{ print $1}'
LC_ALL=C 英文输出
1,ifconfig 输出ip相关信息
# LC_ALL=C ifconfig
eth0 Link encap:Ethernet HWaddr C2:AC:C3:E7:4A:33
inet addr:192.168.1.247 Bcast:0.0.0.0 Mask:255.255.255.0
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:84080 errors:0 dropped:80 overruns:0 frame:0
TX packets:3595264 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:14627750 (13.9 MiB) TX bytes:417627051 (398.2 MiB)
Interrupt:27
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
UP LOOPBACK RUNNING MTU:16436 Metric:1
RX packets:127 errors:0 dropped:0 overruns:0 frame:0
TX packets:127 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:18079 (17.6 KiB) TX bytes:18079 (17.6 KiB)
2,grep 'inet addr:' 截取包含ip的那两行
inet addr:192.168.1.247 Bcast:0.0.0.0 Mask:255.255.255.0
inet addr:127.0.0.1 Mask:255.0.0.0
3,grep -v '127.0.0.1' 去掉本地指向的那行
inet addr:192.168.1.247 Bcast:0.0.0.0 Mask:255.255.255.0
4,cut -d: -f2 -d: 以:分割字符串 -f2:取第二组数据
192.168.1.247 Bcast
5,awk '{ print $1}' $1 表示默认以空格分割的第一组 同理 $@表示第二组
192.168.1.247
# LC_ALL=C ifconfig|grep "inet addr:"|grep -v "127.0.0.1"|cut -d: -f2|awk '{print $2}'
Bcast
二、FreeBSD/OpenBSD:
awk '{ print $2}'
三、Solaris:
awk '{ print $2}'
三段代码的原理类似,都是先获取含有IP的行,再去掉含有127.0.0.1的行。最后获取IP所在的列。
Shell中获取IP地址
Linux下:
cut -d: -f2 | awk '{ print $1}'
先获取含有IP的行,再去掉含有127.0.0.1的行。最后获取IP所在的列:
# Shell script scripts to read ip address
# Get OS name
OS=`uname`
IO="" # store IP
case $OS in
Linux) IP=`ifconfig | grep 'inet addr:'| grep -v '127.0.0.1' | cut -d: -f2 | awk '{ print $1}'`;;
FreeBSD|OpenBSD) IP=`ifconfig | grep -E 'inet.[0-9]' | grep -v '127.0.0.1' | awk '{ print $2}'` ;;
SunOS) IP=`ifconfig -a | grep inet | grep -v '127.0.0.1' | awk '{ print $2} '` ;;
*) IP="Unknown";;
esac
echo "$IP"
附2,
shell获取本机ip地址
一个监控脚本来监测服务运行是否正常,并与短信平台相连,写好后发现报警时需要本机IP地址,写脚本的时候把机器ip地址写死在脚本里 了,当在部署的时候发现问题了
,10多台服务器要逐一修改ip太麻烦了,于是决定自己获取本机ip。
使用ifconfig查看IP地址信息,ip地址是在inet后面的,但是以inet开头的一共有4行,所以需要排除不需要的行,不得不说grep非常好用,有一个-v参数。
文档中的解释为:
Invert the sense of matching, to select non-matching lines. (-v
is specified by POSIX.)
因此,可以使用grep -v来排除,观察这4行,以inet6开头的是不需要的,ip为127.0.0.1开头的也是不需要的,那命令就很简单了,首先取出带ip的这一行
得到的结果:
现在只需要取出ip,这个可以使用强大的awk就非常简单了,代码如下:
然后去掉前面的addr:
完整代码:
另外一些参考方法:
方法一:
方法二: (需要已配置dns)
local_ip=`host $local_host 2>/dev/null | awk ‘{print $NF}’`
方法三:(需要已配置dns)
nslookup -sil $local_host 2>/dev/null | grep Address: | sed ’1d’ | sed ‘s/Address://g’
您可能感兴趣的文章:
获取当前IP地址的shell脚本详解
php 获取用户真实IP与地理位置(淘宝IP接口)的实现代码
php 实现dns域名查询的方法详解(图文)
获取本地网卡IP mac地址 掩码 dns 外网IP的shell脚本
PHP通过IP获取地理位置的代码
php获取远程客户端真实ip地址
php通过IP获取地理位置的实例参考
一个防DDOS攻击的SHELL脚本
shell脚本获取IP地址段的方法
php查询ip所在地代码