在我们的家庭局域网上,重新启动路由器后,我无法从笔记本电脑 A ssh 到笔记本电脑 B,除非通过路由器。但是,在从笔记本电脑 B ping 笔记本电脑 A 后,我可以正常地从 A 连接到 B。我可以通过重新启动路由器来重现此问题。两台笔记本电脑都通过 WiFi 连接到路由器,并且没有连接其他 AP 或路由器。LAN 上还有其他设备,我不知道任何其他 ARP 问题。
路由器重启后演示问题:
scott@laptopa:~$ ip addr show dev wlp58s0 |grep 'inet '
inet 192.168.8.194/24 brd 192.168.8.255 scope global dynamic noprefixroute wlp58s0
scott@laptopa:~$ ssh 192.168.8.131 echo okay
ssh: connect to host 192.168.8.131 port 443: No route to host
scott@laptopa:~$ ssh 192.168.8.131 echo okay
ssh: connect to host 192.168.8.131 port 443: No route to host
scott@laptopa:~$ ssh 192.168.8.131 echo okay
ssh: connect to host 192.168.8.131 port 443: No route to host
scott@laptopa:~$ arp |grep 9c:b6:d0:44:18:09
scott@laptopa:~$
尴尬的解决方法:
scott@laptopa:~$ ssh -o 'ProxyCommand ssh -q -W %h:%p [email protected]' 192.168.8.131 'ping -c 10 192.168.8.194'
PING 192.168.8.194 (192.168.8.194) 56(84) bytes of data.
64 bytes from 192.168.8.194: icmp_seq=1 ttl=64 time=66.3 ms
64 bytes from 192.168.8.194: icmp_seq=2 ttl=64 time=22.9 ms
64 bytes from 192.168.8.194: icmp_seq=3 ttl=64 time=106 ms
64 bytes from 192.168.8.194: icmp_seq=4 ttl=64 time=230 ms
64 bytes from 192.168.8.194: icmp_seq=5 ttl=64 time=252 ms
64 bytes from 192.168.8.194: icmp_seq=6 ttl=64 time=275 ms
64 bytes from 192.168.8.194: icmp_seq=7 ttl=64 time=298 ms
64 bytes from 192.168.8.194: icmp_seq=8 ttl=64 time=321 ms
64 bytes from 192.168.8.194: icmp_seq=9 ttl=64 time=38.3 ms
64 bytes from 192.168.8.194: icmp_seq=10 ttl=64 time=60.3 ms
--- 192.168.8.194 ping statistics ---
10 packets transmitted, 10 received, 0% packet loss, time 9012ms
rtt min/avg/max/mdev = 22.950/167.478/321.937/112.761 ms
证明它现在可以正常工作:
scott@laptopa:~$ ssh 192.168.8.131 echo okay
okay
scott@laptopa:~$ arp |grep 9c:b6:d0:44:18:09
laptopb.lan ether 9c:b6:d0:44:18:09 C wlp58s0
笔记本电脑 A 和 B 都运行 Ubuntu 18.04,路由器是 Lede (OpenWRT) 17.01.4。
正如@roaima 所建议的,我删除了所有
iptables
规则并再次测试。我的问题为零,即使在多次重启路由器后也是如此。然后我iptables
重新添加我的规则并进一步测试。我仍然有零问题。简而言之,我无法再重现该问题,所以它可能像@dirkt 所经历的那样是随机的。也许是网络上的其他设备。