执行以下命令禁用 ping 回复后:
# sysctl net.ipv4.icmp_echo_ignore_all=1
# sysctl -p
我通过 ping localhost 和 127.0.0.1 获得不同的结果
# ping -c 3 localhost
PING localhost(localhost (::1)) 56 data bytes
64 bytes from localhost (::1): icmp_seq=1 ttl=64 time=0.029 ms
64 bytes from localhost (::1): icmp_seq=2 ttl=64 time=0.035 ms
64 bytes from localhost (::1): icmp_seq=3 ttl=64 time=0.101 ms
--- localhost ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 2042ms
rtt min/avg/max/mdev = 0.047/0.072/0.101/0.022 ms
Ping 127.0.0.1 失败:
ping -c 3 127.0.0.1
PING 127.0.0.1 (127.0.0.1) 56(84) bytes of data.
--- 127.0.0.1 ping statistics ---
3 packets transmitted, 0 received, 100% packet loss, time 2032ms
为什么这些结果不同?
答案1
该ping
命令显示将名称解析到的地址。在本例中,它解析为 IPv6 本地主机地址::1
。另一方面,127.0.0.1
是 IPv4 地址,因此它明确ping
使用 IPv4。
您sysctl
使用的 只影响 IPv4 ping,因此您会收到 的回复::1
,但不会收到 的回复127.0.0.1
。
您通过解析获得的地址localhost
取决于您的 DNS 解析器的设置方式。localhost
可能是在 中设置的/etc/hosts
,但理论上您可以从实际的名称服务器获取它。
至于如何删除 IPv6 ping,您可能需要查看,因为IPv6ip6tables
似乎没有类似的内容。sysctl
或者,如果您不在网络中使用 IPv6,则完全禁用 IPv6。 (当然,这不是一个非常具有前瞻性的想法,但如果您目前没有使用它,那么这是可行的。)
答案2
127.0.0.1:
127.0.0.1 是大多数系统的默认环回。环回地址是系统用来验证操作系统网络堆栈的地址。
IPv4 的环回地址可以采用子网中的任何值127.0.0.0/8
IPv6 的环回地址可以采用子网中的任何值::1/128
ping
如果您的网络堆栈在操作系统上运行,则这些范围内的任何值都应该有效。
本地主机:
localhost
是一个主机名,这是一种域名,但在您自己的计算机上是本地的。
该主机名默认指向您的 IPv4 和 IPv6 环回,通常是127.0.0.1
或::1
。
localhost
通过编辑文件可以轻松更改地址/etc/hosts
。
如果您的系统使用该服务systemd-resolved
,则该服务将按照解析 localhost 的方式进行处理。
根据的文档systemd-resolved
:
主机名“localhost”和“localhost.localdomain”(以及任何以“.localhost”或“.localhost.localdomain”结尾的主机名)被解析为 IP 地址
127.0.0.1
和::1
平
当您尝试 ping 主机名或域名时,它会要求操作系统解析该主机名或域名。在您的情况下,您禁用了 localhost,icmpv4
但 localhost 被解析为您的 IPv6 环回和 IPv4 环回,但只有您的 IPv6 环回答案。
区别在于,在一种情况下,您尝试 ping 一个 IP,而在另一种情况下,您尝试 ping 一个可能采用多个值的主机名。
禁用 icmpv6
如果您不需要 IPv6,我建议您禁用它。这将使您在防火墙和配置服务方面需要完成的所有工作增加一倍:
sysctl -w net.ipv6.conf.all.disable_ipv6=0
如果您仍然需要 IPv6 支持并希望避免icmpv6
,您可以使用ip6tables
:
ip6tables -A INPUT -p icmpv6 --icmpv6-type echo-request -j DROP
答案3
本地主机有两个地址:IPv6 地址 ::1 和 IPv4 地址 127.0.0.1。
IPv6 是默认协议,因此 ::1 始终优先于 127.0.0.1。这就是为什么您在要求 ping localhost 时已 ping ::1 的原因。
至于为什么你可以 ping ::1 但无法 ping 127.0.0.1,你的 sysctl 只禁用了 IPv4 的 ping,但没有禁用 IPv6。据我所知,没有相应的 sysctl 来禁用 IPv6 的 ping,但如果确实需要,您可以在防火墙中禁用它(当然无论如何都不建议禁用它)。