shell獲取本機IP


#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的那兩行
 

# LC_ALL=C ifconfig|grep "inet addr:"
          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'   去掉本地指向的那行
 

# LC_ALL=C ifconfig|grep "inet addr:"|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:取第二組數據
 

# LC_ALL=C ifconfig|grep "inet addr:"|grep -v "127.0.0.1"|cut -d: -f2
192.168.1.247  Bcast

5,awk '{ print $1}'  $1 表示默認以空格分割的第一組 同理 $@表示第二組
 

# LC_ALL=C ifconfig|grep "inet addr:"|grep -v "127.0.0.1"|cut -d: -f2|awk '{print $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:
 

LC_ALL=C ifconfig  | grep -E 'inet.[0-9]' | grep -v '127.0.0.1' |
awk '{ print $2}'

三、Solaris:
 

LC_ALL=C ifconfig -a | grep inet | grep -v '127.0.0.1' |
awk '{ print $2}'

三段代碼的原理類似,都是先獲取含有IP的行,再去掉含有127.0.0.1的行。最后獲取IP所在的列。

Shell中獲取IP地址
Linux下:
 

ifconfig  | grep 'inet addr:'| grep -v '127.0.0.1' |
cut -d: -f2 | awk '{ print $1}'

先獲取含有IP的行,再去掉含有127.0.0.1的行。最后獲取IP所在的列:
 

復制代碼代碼示例:
#!/bin/sh
# 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參數。
文檔中的解釋為:
 

-v, –invert-match
    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的這一行
 

復制代碼代碼示例:
/sbin/ifconfig -a|grep inet|grep -v 127.0.0.1|grep -v inet6
 

得到的結果:
 

inet addr:192.168.123.5 Bcast:192.168.123.255 Mask:255.255.255.0

現在只需要取出ip,這個可以使用強大的awk就非常簡單了,代碼如下:
 

復制代碼代碼示例:
awk '{print $2}'
 

然后去掉前面的addr:
 

復制代碼代碼示例:
awk '{print $2}'|tr -d "addr:"

完整代碼:

復制代碼代碼示例:
/sbin/ifconfig -a|grep inet|grep -v 127.0.0.1|grep -v inet6|awk '{print $2}'|tr -d "addr:"

另外一些參考方法:
方法一:
 

復制代碼代碼示例:
/sbin/ifconfig|sed -n ‘/inet addr/s/^[^:]*:\([0-9.]\{7,15\}\) .*/\1/p’

方法二: (需要已配置dns)
 

復制代碼代碼示例:
local_host=”` hostname –fqdn`”
local_ip=`host $local_host 2>/dev/null | awk ‘{print $NF}’`

方法三:(需要已配置dns)
 

復制代碼代碼示例:
local_host=”`hostname –fqdn`”
nslookup -sil $local_host 2>/dev/null | grep Address: | sed ’1d’ | sed ‘s/Address://g’
 
 
=============================
 
 

 

=========================================

http://www.jb51.net/article/34370.htm

 

需要獲取本機ip有很多種情景,比如做分布式處理的時候。那么,如何在worker腳本里獲取本機ip?本文列舉了一系列的方法,有長有短,各有優劣,有shell有perl有python

 

 

 

 

 

在使用 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的方法,大家有時間可以搜索下相關內容。

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM