$ /sbin/route -n
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
0.0.0.0 192.168.122.1 0.0.0.0 UG 0 0 0 ens3
192.168.122.0 0.0.0.0 255.255.255.0 U 0 0 0 ens3
$ /sbin/ifconfig
ens3: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.122.202 netmask 255.255.255.0 broadcast 192.168.122.255
inet6 fe80::5054:ff:fe99:5eee prefixlen 64 scopeid 0x20<link>
ether 52:54:00:99:5e:ee txqueuelen 1000 (Ethernet)
RX packets 14906 bytes 18020195 (17.1 MiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 7390 bytes 786783 (768.3 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 35568
lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
inet 127.0.0.1 netmask 255.0.0.0
inet6 ::1 prefixlen 128 scopeid 0x10<host>
loop txqueuelen 1 (Local Loopback)
RX packets 496 bytes 39840 (38.9 KiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 496 bytes 39840 (38.9 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
パケットがホストに到着し、パケットの宛先がループバックアドレス(127.0.0.1)の場合、
ルーティングテーブルの最初の規則に従ってens3(192.168.122.202)に送信され、次にゲートウェイ(192.168.122.1)に転送されますか?
それでは、意図したターゲット(127.0.0.1)がlocalhostにあるので、間違っていませんか?
宛先アドレスがループバックアドレスの場合、実際にルーティングエントリがないのですか?
ありがとうございます。
答え1
カーネルがパケットを処理するとき、ルーティングテーブルはカーネルがパケットを処理するときに最初に考慮するものではありません。最初に表示するために使用できるルールテーブルがありますip rule list
。ip route list
(および廃止予定route
)基本テーブルを一覧表示しますが、優先度が高く、表示するip route show table local
ために実行されたループバックインターフェイスに関連するすべてのパスを一覧表示するローカルテーブルがあります。
ループバックアドレスに送信されたパケットはシステムを離れません。