#ip="$(getent hosts `hostname` | awk '{print $1}')"
#ip="$(ip addr | grep 'state UP' -A2 | tail -n1 | awk '{print $2}' | cut -f1 -d'/')"
===================
http://linux-wiki.cn/wiki/zh-hans/Shell%E4%B8%AD%E8%8E%B7%E5%8F%96%E5%BD%93%E5%89%8DIP%E5%9C%B0%E5%9D%80
http://www.if-not-true-then-false.com/2010/linux-get-ip-address/
http://unix.stackexchange.com/questions/119269/how-to-get-ip-address-using-shell-script
ip addr | grep 'state UP' -A2 | tail -n1 | awk '{print $2}' | cut -f1 -d'/'
http://unix.stackexchange.com/questions/8518/how-to-get-my-own-ip-address-and-save-it-to-a-variable-in-a-shell-script
ip="$(ifconfig | grep -A 1 'eth0' | tail -1 | cut -d ':' -f 2 | cut -d ' ' -f 1)"
===================
http://www.cnblogs.com/starspace/archive/2009/02/13/1390062.html
shell中获取本机ip地址
方法一:
/sbin/ifconfig -a|grep inet|grep -v 127.0.0.1|grep -v inet6|awk '{print $2}'|tr -d "addr:"
or
/sbin/ifconfig|sed -n '/inet addr/s/^[^:]*:\([0-9.]\{7,15\}\) .*/\1/p'
方法二:
local_host="`hostname --fqdn`"
local_ip=`host $local_host 2>/dev/null | awk '{print $NF}'`
方法三:
local_host="`hostname --fqdn`"
nslookup -sil $local_host 2>/dev/null | grep Address: | sed '1d' | sed 's/Address://g'
============================================
http://blog.sina.com.cn/s/blog_4a4163880100cil2.html
获取本机ip地址地址,并保存到变量中
arg=`ifconfig eth0 |grep "inet addr"| cut -f 2 -d ":"|cut -f 1 -d " "`
ipaddr=$arg
echo $ipadd
cut参数简介
-d用来定义分隔符,默认为tab键,
-f表示需要取得哪个字段,2表示取得以-d指定的分隔符分割的第二个字段
当然也可以通过cut取得文件中每行中特定的几个字符,例如:
cut -c3-5 /etc/passwd
就是输出/etc/passwd文件中每行的第三到第五个字符。
-c 和 -f 参数可以跟以下子参数:
N 第N个字符或字段
N- 从第一个字符或字段到文件结束
N-M 从第N个到第M个字符或字段
-M 从第一个到第M个字符或字段
=====================
http://www.jbxue.com/article/8901.htmlv
fconfig返回的信息中包括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’
=========================================
http://www.jb51.net/article/34370.htm
在使用 Gearman 做分布式处理时,各机需要注册一个独立的 job 作为信息反馈,为求方便,Gearman::Worker 脚本 register_function 代码又要通用,于是想到了使用各自的 ip 地址作为 job 命名。
那么怎么在 worker 脚本里获取本机 ip 作为 func 呢?
第一种办法,最简单的,调用 shell:
$ip = `ifconfig eth0|grep -oE '([0-9]{1,3}\.?){4}'|head -n 1`;
注:这里输入是固定的,所以简单的 [0-9]{1,3} 了,如果是在 web 程序等地方验证 ip,需要更严谨!
或:
$ip = `ifconfig eth0|awk -F: '/inet addr/{split($2,a," ");print a[1];exit}'`;
好吧,这样显得太不 perl 了,而且频繁的调用外部 shell 不太好
第二种:
open FH,"ifconfig eth0|";
while(<FH>){
last unless /inet addr:((\d{1,3}\.?){4})/;
print $1;
}
看起来稍微 perl 了一些,虽然实质跟上面的调用 shell 和 grep 法是一样的。
第三种,更 perl 一点,纯粹读文件:
open FH,'<','/etc/sysconfig/network-scripts/ifcfg-eth0';
while(<FH>){
next unless /IPADDR\s*=\s*(\S+)/;
print $1;
}
进一步的,如果不一定 rh 系,还要去读 /etc/issue ,确定网络配置文件到底是 /etc/sysconfig/network-script/ifcfg-eth0 还是 /etc/network/interfaces 还是其他,然后根据不同发行版写不同的处理方法……额,这是打算自己写模块么?
好吧,大家来充分体会 CPAN 的魅力,去 search 一下,找到一把 Sys::HostIP、Sys::HostAddr、Net::Inetface 等模块。
第四种:
use Sys::HostAddr;
my $interface = Sys::HostAddr->new(ipv => '4', interface => 'eth0');
print $interface->main_ip;
不过进去看看pm文件,汗,这几个模块都是调用ifconfig命令,不过是根据发行版的不同进行封装而已。
第五种:
perl -MPOSIX -MSocket -e 'my $host = (uname)[1];print inet_ntoa(scalar gethostbyname($host))';
不过有童鞋说了,这个可能因为hostname的原因,导致获取的都是127.0.0.1……
那么最后还有一招。通过 strace ifconfig 命令可以看到,linux 实质是通过 ioctl 命令完成的网络接口 ip 获取。那么,我们也用 ioctl 就是了!
第六种如下:
#!/usr/bin/perl
use strict;
use warnings;
use Socket;
require 'sys/ioctl.ph';
sub get_ip_address($) {
my $pack = pack("a*", shift);
my $socket;
socket($socket, AF_INET, SOCK_DGRAM, 0);
ioctl($socket, SIOCGIFADDR(), $pack);
return inet_ntoa(substr($pack,20,4));
};
print get_ip_address("eth0");
这样的好处,就是只调用了核心模块,在分发脚本时,不用连带安装其他模块。
注:这个其实是根据网上有的一个 py 的脚本修改的
py版如下:
#!/usr/bin/python
import socket
import fcntl
import struct
def get_ip_address(ifname):
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
return socket.inet_ntoa(fcntl.ioctl(
s.fileno(),
0x8915, # SIOCGIFADDR
struct.pack('256s', ifname[:15])
)[20:24])
print get_ip_address('eth0')
2012年12月19日增:
为logstash的input/file.rb找到。
ruby版本的:
#!/usr/bin/ruby
require 'socket'
SIOCGIFADDR = 0x8915 # get PA address
def get_ip_address(iface)
begin
sock = UDPSocket.new
buf = [iface,""].pack('a16h16')
sock.ioctl(SIOCGIFADDR, buf);
sock.close
buf[20..24].unpack("CCCC").join(".")
rescue
nil
end
end
if $0 == __FILE__
puts get_ip_address('eth0')
end
不过看puppet里还是用ifconfig的方法,大家有时间可以搜索下相关内容。