web-dev-qa-db-ja.com

Linuxマシンでルーティングテーブルをデバッグするためのツール?

Linuxマシンでルーティングテーブルをデバッグするツールはありますか?

IPアドレスを入力することで使用できるものを意味します。既存のルーティングテーブルが考慮され、テーブルからの一致が出力されるため、パケットがどこに行くのかを知ることができますか?

19
leeand00

使用する ip route get。 From ネットワークルーティングの構成

ip route getコマンドは、指定したIPアドレスに到達するためにシステムがパケットを送信するルートを照会できる便利な機能です。次に例を示します。

# ip route get 23.6.118.140
23.6.118.140 via 10.0.2.2 dev eth0 src 10.0.2.15
cache mtu 1500 advmss 1460 hoplimit 64

この例では、23.6.118.140へのパケットは、ゲートウェイ10.0.2.2を介してeth0インターフェイスから送信されます。

40
Mark Plotnick

次のスクリプトを便利な場所に保存します。テストするIPアドレスを指定して呼び出します。対応するルートが表示されます。

#!/bin/bash
#
# Find the appropriate routing entry for a given IP address
########################################################################

########################################################################
# Calculate the base network address for a given addres and netmask
#
baseNet() {
    local ADDRESS="$1" NETMASK="$2"
    ipcalc -nb "$ADDRESS" "$NETMASK" | awk '$1=="Network:"{print $2}'
}

########################################################################
# Go
#
for IPADDRESS in "$@"
do
    netstat -rn |
        tac |
        while read DESTINATION GATEWAY GENMASK FLAGS MSS WINDOW IRTT IFACE
        do
            NSBASENET=$(baseNet "$DESTINATION" "$GENMASK")
            IPBASENET=$(baseNet "$IPADDRESS" "$GENMASK")
            if test "X$NSBASENET" = "X$IPBASENET"
            then
                if test '0.0.0.0' = "$GATEWAY"
                then
                    echo "Matches $DESTINATION with netmask $GENMASK directly on $IFACE"
                else
                    echo "Matches $DESTINATION with netmask $GENMASK via $GATEWAY on $IFACE"
                fi
                break
            fi
        done
done

# All done
#
exit 0

使用例

./what-route.sh 10.0.5.6
Matches 0.0.0.0 with netmask 0.0.0.0 via 10.0.2.2 on eth0
./what-route.sh 10.0.2.6
Matches 10.0.2.0 with netmask 255.255.255.0 directly on eth0
2
roaima