Edytowane ( 2014-06-01 2018-01-09)
Dla silniejszej konfiguracji, z wieloma interfejsami i wieloma adresami IP skonfigurowanymi na każdym interfejsie, napisałem czysty skrypt bash (nie oparty na 127.0.0.1
) w celu znalezienia poprawnego interfejsu i adresu IP, na podstawie default route
. Publikuję ten skrypt na samym dole tej odpowiedzi.
Wprowadzenie
Jak oba Os grzmotnąć zainstalowana domyślnie, jest wskazówka bash dla komputerów Mac i Linux:
Problemowi ustawień regionalnych zapobiega się poprzez użycie 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
Umieszczenie tego w funkcji:
Minimalny:
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)
}
Proste użycie:
getMyIP
192.168.1.37
Fantazyjne porządki:
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
}
Stosowanie:
getMyIP
192.168.1.37
lub z uruchomioną tą samą funkcją, ale z argumentem:
getMyIP varHostIP
echo $varHostIP
192.168.1.37
set | grep ^varHostIP
varHostIP=192.168.1.37
Nota: Bez argumentu ta funkcja generuje na STDOUT, adres IP i znak nowej linii , z argumentem nic nie jest drukowane, ale tworzona jest zmienna o nazwie jako argument i zawiera adres IP bez znaku nowego wiersza .
Nota2: Zostało to przetestowane na Debianie, LaCie zhakowała nas i MaxOs. Jeśli to nie zadziała w twoim środowisku, będę bardzo zainteresowany informacjami zwrotnymi!
Starsza wersja tej odpowiedzi
(Nie usunięty, ponieważ oparty na sed
, nie bash
.)
Ostrzeżenie: istnieje problem z ustawieniami regionalnymi!
Szybki i mały:
myIP=$(ip a s|sed -ne '/127.0.0.1/!{s/^[ \t]*inet[ \t]*\([0-9.]\+\)\/.*$/\1/p}')
Eksplodował (też działa;)
myIP=$(
ip a s |
sed -ne '
/127.0.0.1/!{
s/^[ \t]*inet[ \t]*\([0-9.]\+\)\/.*$/\1/p
}
'
)
Edytować:
W jaki sposób! Wygląda na to, że nie działa w systemie Mac OS ...
Ok, wydaje się, że działa to tak samo w systemie Mac OS, jak w moim systemie 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; }')
podzielony:
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;
}')
Mój skrypt (styczeń 2018 r.):
Skrypt ten najpierw znajdzie domyślną trasę i interfejs , a następnie wyszuka lokalną sieć IP dopasowującą bramę i zapełni zmienne. Ostatnie dwa wiersze po prostu drukują, coś w stylu:
Interface : en0
Local Ip : 10.2.5.3
Gateway : 10.2.4.204
Net mask : 255.255.252.0
Run on mac : true
lub
Interface : eth2
Local Ip : 192.168.1.31
Gateway : 192.168.1.1
Net mask : 255.255.255.0
Run on mac : false
Cóż, oto:
#!/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