web-dev-qa-db-ja.com

LinuxとOS XでローカルマシンのプライマリIPアドレスを取得する方法

ローカルホストのプライマリ(最初の)IPアドレス(127.0.0.1以外)を返すコマンドラインソリューションを探しています。

このソリューションは少なくともLinux(DebianとRedHat)とOS X 10.7以降で動作するはずです。

私はifconfigが両方で利用可能であることを知っていますが、その出力はこれらのプラットフォームの間でそれほど一貫していません。

287
sorin

grepを使用してifconfigからIPアドレスをフィルタリングします。

ifconfig | grep -Eo 'inet (addr:)?([0-9]*\.){3}[0-9]*' | grep -Eo '([0-9]*\.){3}[0-9]*' | grep -v '127.0.0.1'

あるいはsedの場合:

ifconfig | sed -En 's/127.0.0.1//;s/.*inet (addr:)?(([0-9]*\.){3}[0-9]*).*/\2/p'

特定のインタフェース、wlan0、eth0などにのみ興味があるのなら、

ifconfig wlan0 | ...

あなたの.bashrcの中のコマンドを create / myipと呼ばれるあなた自身のコマンドにエイリアスすることができます。

alias myip="ifconfig | sed -En 's/127.0.0.1//;s/.*inet (addr:)?(([0-9]*\.){3}[0-9]*).*/\2/p'"

もっと簡単な方法はhostname -Iです(古いバージョンのhostnameではhostname -iですが、コメントを見てください)。ただし、これはLinux上のみです。

423
Chris Seymour

Linuxマシン(OS X以外)の場合:

hostname --ip-address
198
ACyclic

以下はLinuxでは動作しますが、OSXでは動作しません。

これは全くDNSに頼らず、/etc/hostsが正しく設定されていなくても機能します(11.0.0.0の省略形です):

ip route get 1 | awk '{print $NF;exit}'

またはawkを避け、8.8.8.8にGoogleのパブリックDNSを使用してわかりやすくします。

ip route get 8.8.8.8 | head -1 | cut -d' ' -f8

信頼性の低い方法:(下記のコメントを参照)

hostname -I | cut -d' ' -f1
194
Collin Anderson

編集済み(2014-06-01 2018-01-09)

より強力な設定のために、各インターフェイスに設定された多くのインターフェイスと多くのIPを使用して、正しいインターフェイスipを見つけるための127.0.0.1に基づいていないpure bashスクリプトを書きました。 default route。私はこの答えの最後にこのスクリプトを載せています。

イントロ

両方のOSにデフォルトで bash がインストールされているので、MacとLinuxの両方にbashのヒントがあります。

ロケールの問題はLANG=Cの使用によって防止されます。

myip=
while IFS=$': \t' read -a line ;do
    [ -z "${line%inet}" ] && ip=${line[${#line[1]}>4?1:2]} &&
        [ "${ip#127.0.0.1}" ] && myip=$ip
  done< <(LANG=C /sbin/ifconfig)
echo $myip

これを関数に入れる:

最小:

getMyIP() {
    local _ip _line
    while IFS=$': \t' read -a _line ;do
        [ -z "${_line%inet}" ] &&
           _ip=${_line[${#_line[1]}>4?1:2]} &&
           [ "${_ip#127.0.0.1}" ] && echo $_ip && return 0
      done< <(LANG=C /sbin/ifconfig)
}

簡単な使い方

getMyIP
192.168.1.37

ファンシー整頓:

getMyIP() {
    local _ip _myip _line _nl=$'\n'
    while IFS=$': \t' read -a _line ;do
        [ -z "${_line%inet}" ] &&
           _ip=${_line[${#_line[1]}>4?1:2]} &&
           [ "${_ip#127.0.0.1}" ] && _myip=$_ip
      done< <(LANG=C /sbin/ifconfig)
    printf ${1+-v} $1 "%s${_nl:0:$[${#1}>0?0:1]}" $_myip
}

使用法:

getMyIP
192.168.1.37

または、同じ関数を実行しますが、引数を取ります。

getMyIP varHostIP
echo $varHostIP
192.168.1.37
set | grep ^varHostIP
varHostIP=192.168.1.37

Nota: 引数なしで、この関数はSTDOUTに出力し、IPとnewlineを引数付きで何も表示しませんが、引数として指定された変数が作成され、newlineなしでIPを含みます。

Nota2: これはDebian、LaCie、nas、MaxOでテストされています。これがあなたの環境下でうまくいかない場合、私はフィードバックによって非常に興味があるでしょう!

この回答の古いバージョン

sedではなくbashに基づいているため削除されません。)

警告:ロケールに関する問題があります。

早くて小さい

myIP=$(ip a s|sed -ne '/127.0.0.1/!{s/^[ \t]*inet[ \t]*\([0-9.]\+\)\/.*$/\1/p}')

爆発(あまりにも作業)

myIP=$(
    ip a s |
    sed -ne '
        /127.0.0.1/!{
            s/^[ \t]*inet[ \t]*\([0-9.]\+\)\/.*$/\1/p
        }
    '
)

編集:

どうやって!これはMac OSでは動作しないようです ...

さて、これはMac OSでも私のLinuxと全く同じように動作するようです。

myIP=$(LANG=C /sbin/ifconfig  | sed -ne $'/127.0.0.1/ ! { s/^[ \t]*inet[ \t]\\{1,99\\}\\(addr:\\)\\{0,1\\}\\([0-9.]*\\)[ \t\/].*$/\\2/p; }')

分割:

myIP=$(
    LANG=C /sbin/ifconfig  |
        sed -ne $'/127.0.0.1/ ! {
            s/^[ \t]*inet[ \t]\\{1,99\\}\\(addr:\\)\\{0,1\\}\\([0-9.]*\\)[ \t\/].*$/\\2/p;
        }')

私のスクリプト(2018年1月):

このスクリプトは最初にあなたのdefault routeinterfaceが使われているのを見つけて、それからgatewayのlocal ip matching networkを検索して変数を設定します。最後の2行は、ちょうど次のように表示されます。

Interface   : en0
Local Ip    : 10.2.5.3
Gateway     : 10.2.4.204
Net mask    : 255.255.252.0
Run on mac  : true

または

Interface   : eth2
Local Ip    : 192.168.1.31
Gateway     : 192.168.1.1
Net mask    : 255.255.255.0
Run on mac  : false

まあ、それはあります:

#!/bin/bash
runOnMac=false
int2ip() { printf ${2+-v} $2 "%d.%d.%d.%d" \
        $(($1>>24)) $(($1>>16&255)) $(($1>>8&255)) $(($1&255)) ;}
ip2int() { local _a=(${1//./ }) ; printf ${2+-v} $2 "%u" $(( _a<<24 |
                  ${_a[1]} << 16 | ${_a[2]} << 8 | ${_a[3]} )) ;}
while IFS=$' :\t\r\n' read a b c d; do
    [ "$a" = "usage" ] && [ "$b" = "route" ] && runOnMac=true
    if $runOnMac ;then
        case $a in 
            gateway )    gWay=$b  ;;
            interface )  iFace=$b ;;
        esac
    else
        [ "$a" = "0.0.0.0" ] && [ "$c" = "$a" ] && iFace=${d##* } gWay=$b
    fi
done < <(/sbin/route -n 2>&1 || /sbin/route -n get 0.0.0.0/0)
ip2int $gWay gw
while read lhs rhs; do
    [ "$lhs" ] && { 
        [ -z "${lhs#*:}" ] && iface=${lhs%:}
        [ "$lhs" = "inet" ] && [ "$iface" = "$iFace" ] && {
            mask=${rhs#*netmask }
            mask=${mask%% *}
            [ "$mask" ] && [ -z "${mask%0x*}" ] &&
                printf -v mask %u $mask ||
                ip2int $mask mask
            ip2int ${rhs%% *} ip
            (( ( ip & mask ) == ( gw & mask ) )) &&
                int2ip $ip myIp && int2ip $mask netMask
        }
    }
done < <(/sbin/ifconfig)
printf "%-12s: %s\n" Interface $iFace Local\ Ip $myIp \
       Gateway $gWay Net\ mask $netMask Run\ on\ mac $runOnMac
32
F. Hauri

linuxで

hostname -I

macOS上

ipconfig getifaddr en0

hostname -Iは信頼できない順序で複数のアドレスを返す可能性があることに注意してください( man hostname を参照)。しかし、私にとっては192.168.1.Xが返されるだけです。

26
Boris

溶液

$ ip -o route get to 8.8.8.8 | sed -n 's/.*src \([0-9.]\+\).*/\1/p'
192.168.8.16

説明

ネットワーク情報を問い合わせる correct の方法はipを使うことです:

  • -o 1行出力
  • 宛先への実際のカーネル経路を取得するroute get to
  • 8.8.8.8 GoogleのIPアドレスですが、到達したい実際のIPアドレスを使用できます

例えばipの出力:

8.8.8.8 via 192.168.8.254 dev enp0s25 src 192.168.8.16 uid 1000 \   cache

src ipを抽出するために、sedが最も適切であり、正規表現サポートと最も互換性があります。

  • デフォルトでは-n出力なし
  • 's/pattern/replacement/p'一致パターンおよび印刷置換のみ
  • .*src \([0-9.]\+\).*8.8.8.8に到達するためにカーネルによって使用されるsrc IPと一致します

例えば最終出力:

192.168.8.16

その他の回答

最近のマシンではうまく動かないので、上記の答えはどれも私には十分ではないと思います(Gentoo 2018)。

私は前の答えと見つけた問題:

  • コマンド出力における定位置列の使用。
  • ifconfigの使用は推奨されていません。たとえば、複数のIPをリストしないでください。
  • sedが処理できる単純なタスクにawkを使用する。
  • ip route get 1は不明確で、実際にはip route get to 1.0.0.0のエイリアスです
  • すべてのアプライアンスに-Iオプションがなく、私の場合は127.0.0.1を返すhostnameコマンドの使用。
24
giosh94mhz

これは127.0.0.1と言っているだけかもしれませんが、これを試すこともできます。

hostname  -i

または

hostname -I
22
user3173508

Linuxでこのコマンドを使用してeth0のIPバージョン4アドレスを取得することもできます。

/sbin/ip -4 -o addr show dev eth0| awk '{split($4,a,"/");print a[1]}'

出力はこのようになります

[root@localhost Sathish]# /sbin/ip -4 -o addr show dev eth0| awk '{split($4,a,"/");print a[1]}'
192.168.1.22
22
Sathish

これはLinuxとOSXで動作します

これにより、デフォルトルートに関連付けられているインターフェイスが取得されます。

NET_IF=`netstat -rn | awk '/^0.0.0.0/ {thif=substr($0,74,10); print thif;} /^default.*UG/ {thif=substr($0,65,10); print thif;}'`

上記で発見したインタフェースを使用して、IPアドレスを取得します。

NET_IP=`ifconfig ${NET_IF} | grep -Eo 'inet (addr:)?([0-9]*\.){3}[0-9]*' | grep -Eo '([0-9]*\.){3}[0-9]*' | grep -v '127.0.0.1'`

OSX

uname -a

ダーウィンラップトップ14.4.0ダーウィンカーネルバージョン14.4.0:木5月28日11時35分04秒PDT。 root:xnu-2782.30.5〜1/RELEASE_X86_64 x86_64

echo $NET_IF

en5

echo $NET_IP

192.168.0.130

CentOS Linux

uname -a

Linux dev-cil.medfx.local 2.6.18-164.el5xen 1 SMP木9月3日4:03:03 EDT 2009 x86_64 x86_64 x86_64 GNU/Linux

echo $NET_IF

eth0

echo $NET_IP

192.168.46.10

14
Colin Fletcher

他の方法のいくつかを使用するシステムで複数のIPアドレスが定義されている場合、競合が発生する場合があります。この行は、デフォルトで使用されるIPアドレスを常に取得します。

ip route get 8.8.8.8 | head -1 | awk '{print $7}'
11
Kjeld Flarup

私はCollin Andersonsに、2つのインターフェースがあり、両方ともupとして表示されている場合にも、この方法も考慮に入れると答えなければなりません。

ip route get 1 | awk '{print $NF;exit}'

私はRaspberry Piを使ってアプリケーションを開発していましたが、実際に使用されていたIPアドレスが必要かどうかだけではありませんでした。他の答えのほとんどは、必ずしも有用ではない両方のIPアドレスを返します - とにかく私のシナリオでは。

6
c7borg

私はこの答えに対する私のコメントを抜き出している。

ip route get 1 | sed -n 's/^.*src \([0-9.]*\) .*$/\1/p'

それは私の場合はうまくいきませんでした@CollinAnderson回答に基づいています。

6
estani

プライマリネットワークインタフェースIP

ifconfig `ip route | grep default | head -1 | sed 's/\(.*dev \)\([a-z0-9]*\)\(.*\)/\2/g'` | grep -oE "\b([0-9]{1,3}\.){3}[0-9]{1,3}\b" | head -1
5
kaspars

デフォルトゲートウェイであるネットワーク内でこのコンピュータのIPアドレスを検索します(たとえば、すべての仮想ネットワーク、dockerブリッジを除く)。インターネットゲートウェイ、無線LANゲートウェイ、イーサネット

ip route| grep $(ip route |grep default | awk '{ print $5 }') | grep -v "default" | awk '/scope/ { print $9 }'

Linux上で動作します。

テスト:

➜  ~ ip route| grep $(ip route |grep default | awk '{ print $5 }') | grep -v "default" | awk '/scope/ { print $9 }'
192.168.0.114

➜  reverse-networking git:(feature/type-local) ✗ ifconfig wlp2s0
wlp2s0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.0.114  netmask 255.255.255.0  broadcast 192.168.0.255
        inet6 fe80::d3b9:8e6e:caee:444  prefixlen 64  scopeid 0x20<link>
        ether ac:x:y:z  txqueuelen 1000  (Ethernet)
        RX packets 25883684  bytes 27620415278 (25.7 GiB)
        RX errors 0  dropped 27  overruns 0  frame 0
        TX packets 7511319  bytes 1077539831 (1.0 GiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

すべてのノードパッケージがあります。クロスプラットフォームで使いやすいです。

$ npm install --global internal-ip-cli

$ internal-ip
fe80::1

$ internal-ip --ipv4
192.168.0.3

これは物議を醸しているアプローチですが、ツーリングのためにnpmを使用することは、それがあるかどうかにかかわらず、より一般的になっています。

4
Dennis
ifconfig | grep 'inet ' | grep -v '127.0.0.1' | awk '{print $2}'
4
Faizan Noor

あなたのLinuxシステムであなたのローカルipv4-addressを得るための最短の方法:

hostname -I | awk '{print $1}'
4
harry

LinuxとOSXの両方で機能する別のifconfigバリエーション:

ifconfig | grep "inet " | cut -f2 -d' '
3
ccpizza

私はたくさんのリンク(StackExchange、AskUbuntu、StackOverflowなど)を調べ、すべての最良の解決策を1つのシェルスクリプトにまとめることにしました。

私の意見では、これら2つの品質保証は最もよく見られるものです。

シェルスクリプトで外部IPアドレスを取得する方法を教えてください。 https://unix.stackexchange.com/q/22615

内部IPアドレスはどうやって見つけるのですか? https://askubuntu.com/a/604691

これが彼のリポジトリ( https://github.com/rsp/scripts/ )で共有されているrspによるいくつかのアイデアに基づく私の解決策です。

このスクリプトは非常に単純な作業では非常に大きいと言う人もいますが、できるだけ簡単に柔軟に使用できるようにしたいと思います。それはデフォルト値を再定義することを可能にする簡単な設定ファイルをサポートします。

Cygwin、MINGW、Linux(Red Hat)でテストに成功しました。

内部IPアドレスを表示

myip -i

外部IPアドレスを表示

myip -e

リンクからも入手可能なソースコード: https://github.com/ildar-shaimordanov/tea-set/blob/master/home/bin/myip 。設定ファイルの例は、メインスクリプトの横にあります。

#!/bin/bash

# =========================================================================
#
# Getting both internal and external IP addresses used for outgoing 
# Internet connections.
#
# Internal IP address is the IP address of your computer network interface 
# that would be used to connect to Internet.
#
# External IP address is the IP address that is visible by external 
# servers that you connect to over Internet.
#
# Copyright (C) 2016 Ildar Shaimordanov
#
# =========================================================================

# Details of the actual implementation are based on the following QA:
#
# How can I get my external IP address in a Shell script?
# https://unix.stackexchange.com/q/22615
#
# How do I find my internal ip address?
# https://askubuntu.com/a/604691

# =========================================================================

for f in \
    "$( dirname "$0" )/myip.conf" \
    ~/.myip.conf \
    /etc/myip.conf
do
    [ -f "$f" ] && {
        . "$f"
        break
    }
done

# =========================================================================

show_usage() {
    cat - <<HELP
USAGE
  $( basename "$0" ) [OPTIONS]

DESCRIPTION
  Display the internal and external IP addresses

OPTIONS
  -i  Display the internal IP address
  -e  Display the external IP address
  -v  Turn on verbosity
  -h  Print this help and exit
HELP
    exit
}

die() {
    echo "$( basename "$0" ): $@" >&2
    exit 2
}

# =========================================================================

show_internal=""
show_external=""
show_verbose=""

while getopts ":ievh" opt
do
    case "$opt" in
    i )
        show_internal=1
        ;;
    e )
        show_external=1
        ;;
    v )
        show_verbose=1
        ;;
    h )
        show_usage
        ;;
    \? )
        die "Illegal option: $OPTARG"
        ;;
    esac
done

if [ -z "$show_internal" -a -z "$show_external" ]
then
    show_internal=1
    show_external=1
fi

# =========================================================================

# Use Google's public DNS to resolve the internal IP address
[ -n "$TARGETADDR" ] || TARGETADDR="8.8.8.8"

# Query the specific URL to resolve the external IP address
[ -n "$IPURL" ] || IPURL="ipecho.net/plain"

# Define explicitly $IPCMD to gather $IPURL using another tool
[ -n "$IPCMD" ] || {
    if   which curl >/dev/null 2>&1
    then
        IPCMD="curl -s"
    Elif which wget >/dev/null 2>&1
    then
        IPCMD="wget -qO -"
    else
        die "Neither curl nor wget installed"
    fi
}

# =========================================================================

resolveip() {
    {
        gethostip -d "$1" && return
        getent ahostsv4 "$1" \
        | grep RAW \
        | awk '{ print $1; exit }' 
    } 2>/dev/null
}

internalip() {
    [ -n "$show_verbose" ] && printf "Internal: "

    case "$( uname | tr '[:upper:]' '[:lower:]' )" in
    cygwin* | mingw* | msys* )
        netstat -rn \
        | grep -w '0.0.0.0' \
        | awk '{ print $4 }'
        return
        ;;
    esac

    local t="$( resolveip "$TARGETADDR" )"
    [ -n "$t" ] || die "Cannot resolve $TARGETADDR"
    ip route get "$t" \
    | awk '{ print $NF; exit }'
}

externalip() {
    [ -n "$show_verbose" ] && printf "External: "

    eval $IPCMD "$IPURL" $IPOPEN
}

# =========================================================================

[ -n "$show_internal" ] && internalip
[ -n "$show_external" ] && externalip

# =========================================================================

# EOF
3
jsxt
ip addr show | grep -E '^\s*inet' | grep -m1 global | awk '{ print $2 }' | sed 's|/.*||'
3
rbolante

Network Interface Names を使っているだけで、私のカスタムコマンドは

[[ $(ip addr | grep enp0s25) != '' ]] && ip addr show dev enp0s25 | sed -n -r 's@.*inet (.*)/.*brd.*@\1@p' || ip addr show dev eth0 | sed -n -r 's@.*inet (.*)/.*brd.*@\1@p' 

自分のノートに

[flying@lempstacker ~]$ cat /etc/redhat-release 
CentOS Linux release 7.2.1511 (Core) 
[flying@lempstacker ~]$ [[ $(ip addr | grep enp0s25) != '' ]] && ip addr show dev enp0s25 | sed -n -r 's@.*inet (.*)/.*brd.*@\1@p' || ip addr show dev eth0 | sed -n -r 's@.*inet (.*)/.*brd.*@\1@p'
192.168.2.221
[flying@lempstacker ~]$

しかし、ネットワークインターフェースが少なくとも1つのIPを所有している場合は、すべてのIPがそれに属していることが示されます。

例えば

Ubuntu 16.10

root@yakkety:~# sed -r -n 's@"@@g;s@^VERSION=(.*)@\1@p' /etc/os-release
16.04.1 LTS (Xenial Xerus)
root@yakkety:~# [[ $(ip addr | grep enp0s25) != '' ]] && ip addr show dev enp0s25 | sed -n -r 's@.*inet (.*)/.*brd.*@\1@p' || ip addr show dev eth0 | sed -n -r 's@.*inet (.*)/.*brd.*@\1@p'
178.62.236.250
root@yakkety:~#

Debian Jessie

root@jessie:~# sed -r -n 's@"@@g;s@^PRETTY_NAME=(.*)@\1@p' /etc/os-release
Debian GNU/Linux 8 (jessie)
root@jessie:~# [[ $(ip addr | grep enp0s25) != '' ]] && ip addr show dev enp0s25 | sed -n -r 's@.*inet (.*)/.*brd.*@\1@p' || ip addr show dev eth0 | sed -n -r 's@.*inet (.*)/.*brd.*@\1@p'
192.81.222.54
root@jessie:~# 

CentOS 6.8

[root@centos68 ~]# cat /etc/redhat-release 
CentOS release 6.8 (Final)
[root@centos68 ~]# [[ $(ip addr | grep enp0s25) != '' ]] && ip addr show dev enp0s25 | sed -n -r 's@.*inet (.*)/.*brd.*@\1@p' || ip addr show dev eth0 | sed -n -r 's@.*inet (.*)/.*brd.*@\1@p'
162.243.17.224
10.13.0.5
[root@centos68 ~]# ip route get 1 | awk '{print $NF;exit}'
162.243.17.224
[root@centos68 ~]#

Fedora 24

[root@Fedora24 ~]# cat /etc/redhat-release 
Fedora release 24 (Twenty Four)
[root@Fedora24 ~]# [[ $(ip addr | grep enp0s25) != '' ]] && ip addr show dev enp0s25 | sed -n -r 's@.*inet (.*)/.*brd.*@\1@p' || ip addr show dev eth0 | sed -n -r 's@.*inet (.*)/.*brd.*@\1@p'
104.131.54.185
10.17.0.5
[root@Fedora24 ~]# ip route get 1 | awk '{print $NF;exit}'
104.131.54.185
[root@Fedora24 ~]#

link によって提供されるコマンドip route get 1 | awk '{print $NF;exit}'はより正確で、さらに詳細で、もっと短くなっているようです。

3
user7040344

他の国々から見たあなたのプライマリ public IPが必要であると仮定して、それらのうちのどれでも試してください:

wget http://ipecho.net/plain -O - -q
curl http://icanhazip.com
curl http://ifconfig.me/ip
3
Putnik

これがすべてのOSで機能するかどうかわからない場合は、試してみてください。

ifconfig | awk -F"[ :]+" '/inet addr/ && !/127.0/ {print $4}'
2
Jotne

ネットワークインターフェース(eth0、wlan、tun0など)を知っているなら:

ifconfig eth0 | grep addr: | awk '{ print $2 }' | cut -d: -f2
1
droidgren

npmnodeがインストールされている場合:npm install -g ip && node -e "const ip = require('ip'); console.log(ip.address())"

1
Antoine F.

Mac、LinuxおよびDockerコンテナ内で動作します。

$ hostname --ip-address 2> /dev/null || (ifconfig | sed -En 's/127.0.0.1//;s/.*inet (addr:)?(([0-9]*\.){3}[0-9]*).*/\2/p' | awk '{print $ 1;出口}')

Makefileでは以下のようにも動作します。

LOCAL_Host := ${Shell hostname --ip-address 2> /dev/null || (ifconfig | sed -En 's/127.0.0.1//;s/.*inet (addr:)?(([0-9]*\.){3}[0-9]*).*/\2/p' | awk '{print $1; exit}')}

1
peleteiro
ifconfig $(netstat -rn | grep -E "^default|^0.0.0.0" | head -1 | awk '{print $NF}') | grep 'inet ' | awk '{print $2}' | grep -Eo '([0-9]*\.){3}[0-9]*' 
1
AlanG
ifconfig | grep "inet addr:" | grep -v "127.0.0.1" | grep -Eo '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}'  | head -1
1
user2802053

Linuxの場合、必要なものは次のコマンドです。

ifconfig $1|sed -n 2p|awk '{ print $2 }'|awk -F : '{ print $2 }'

あなたのシェルにこれをタイプすれば、あなたは単にあなたのIPを知るでしょう。

1
Statham

これは読みやすいです:ifconfig | grep 'inet addr:' |/usr/bin/awk '{print $2}' | tr -d addr:

1
Cory Thorson

Macでは、次の点を考慮してください。

scutil --nwi | grep -Eo '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}'
0
cl0kc