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的那两行
3,grep -v '127.0.0.1' 去掉本地指向的那行
4,cut -d: -f2 -d: 以:分割字符串 -f2:取第二组数据
5,awk '{ print $1}' $1 表示默认以空格分割的第一组 同理 $@表示第二组
二、FreeBSD/OpenBSD:
三、Solaris:
三段代码的原理类似,都是先获取含有IP的行,再去掉含有127.0.0.1的行。最后获取IP所在的列。
Shell中获取IP地址
Linux下:
先获取含有IP的行,再去掉含有127.0.0.1的行。最后获取IP所在的列:
附2,
shell获取本机ip地址
一个监控脚本来监测服务运行是否正常,并与短信平台相连,写好后发现报警时需要本机IP地址,写脚本的时候把机器ip地址写死在脚本里 了,当在部署的时候发现问题了
,10多台服务器要逐一修改ip太麻烦了,于是决定自己获取本机ip。
使用ifconfig查看IP地址信息,ip地址是在inet后面的,但是以inet开头的一共有4行,所以需要排除不需要的行,不得不说grep非常好用,有一个-v参数。
文档中的解释为:
因此,可以使用grep -v来排除,观察这4行,以inet6开头的是不需要的,ip为127.0.0.1开头的也是不需要的,那命令就很简单了,首先取出带ip的这一行
得到的结果:
现在只需要取出ip,这个可以使用强大的awk就非常简单了,代码如下:
然后去掉前面的addr:
完整代码:
另外一些参考方法:
方法一:
方法二: (需要已配置dns)
方法三:(需要已配置dns)