
Я использую Arch Linux (на Raspberry Pi 3) и попытался подключить Ethernet и Wi-Fi к одной и той же сети. route
Выдает следующее:
$ route
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
default gateway 0.0.0.0 UG 1024 0 0 eth0
default gateway 0.0.0.0 UG 1024 0 0 wlan0
192.168.1.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0
192.168.1.0 0.0.0.0 255.255.255.0 U 0 0 0 wlan0
gateway 0.0.0.0 255.255.255.255 UH 1024 0 0 eth0
gateway 0.0.0.0 255.255.255.255 UH 1024 0 0 wlan0
ip addr
показывает мне следующее:
$ ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000
link/ether b8:27:XX:XX:XX:XX brd ff:ff:ff:ff:ff:ff
inet 192.168.1.103/24 brd 192.168.1.255 scope global dynamic eth0
valid_lft 85717sec preferred_lft 85717sec
inet6 fe80::ba27:ebff:fee4:4f60/64 scope link
valid_lft forever preferred_lft forever
3: wlan0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000
link/ether b8:27:YY:YY:YY:YY brd ff:ff:ff:ff:ff:ff
inet 192.168.1.102/24 brd 192.168.1.255 scope global dynamic wlan0
valid_lft 85727sec preferred_lft 85727sec
inet6 fe80::ba27:ebff:feb1:1a35/64 scope link
valid_lft forever preferred_lft forever
Оба wlan0
интерфейса eth0
смогли получить IP-адрес от маршрутизатора.
Но оказывается, что работает только один из этих интерфейсов. Другой интерфейс не пингуется и не подключается. Обычно работает Ethernet, но иногда Wi-Fi.
Что происходит? Что я могу сделать, чтобы это заработало?
решение1
Как вы уже поняли, с точки зрения маршрутизации иметь адреса из одной сети в разных интерфейсах, хотя это и возможно, не является идеальным решением.
Маршрутизация предполагает наличие разных сетей для каждого интерфейса, и в конечном итоге одна из них будет иметь приоритет над другой при маршрутизации, поскольку они перекрываются.
Рекомендуемым решением при наличии нескольких интерфейсов, подключенных к одной сети, является их объединение в мостовой интерфейс.
Интерфейс моста будет «владеть» IP-адресом, а фактические реальные интерфейсы будут сгруппированы как виртуальная единая сущность под br0
.
allow-hotplug eth0
iface eth0 inet manual
allow-hotplug wlan0
iface wlan0 inet manual
auto br0
iface br0 inet dhcp
bridge_ports eth0 wlan0
Debian Linux: настройка сетевых интерфейсов в качестве моста/сетевого коммутатора
решение2
Это скорее дополнение, чем полное решение. [Поскольку у меня недостаточно «очков репутации», чтобы комментировать.]
Сначала вам нужно заставить оба интерфейса работать независимо. Затем, вместо моста, вы также можете балансировать нагрузку исходящих соединений через оба интерфейса.
https://www.tldp.org/HOWTO/Adv-Routing-HOWTO/lartc.rpdb.multiple-links.html
Я начал с этого — два устройства с маршрутом к Интернету по умолчанию, настроенным сетевым менеджером:
❯ ip route
default via 192.168.0.1 dev eno1 proto dhcp metric 100
default via 192.168.0.1 dev wlp4s0 proto dhcp metric 600
169.254.0.0/16 dev wlp4s0 scope link metric 1000
192.168.0.0/24 dev eno1 proto kernel scope link src 192.168.0.246 metric 100
192.168.0.0/24 dev wlp4s0 proto kernel scope link src 192.168.0.213 metric 600
Затем я использовал команду, описанную здесь в разделе «Балансировка нагрузки»:
https://www.tldp.org/HOWTO/Adv-Routing-HOWTO/lartc.rpdb.multiple-links.html
❯ P1=192.168.0.1
❯ P2=192.168.0.1
❯ IF1=eno1
❯ IF2=wlp4s0
❯ ip route add default scope global nexthop via $P1 dev $IF1 weight 1 \
nexthop via $P2 dev $IF2 weight 1
Вуаля! У меня есть соединение через оба устройства.
❯ ip route
default
nexthop via 192.168.0.1 dev eno1 weight 1
nexthop via 192.168.0.1 dev wlp4s0 weight 1
default via 192.168.0.1 dev eno1 proto dhcp metric 100
default via 192.168.0.1 dev wlp4s0 proto dhcp metric 600
169.254.0.0/16 dev wlp4s0 scope link metric 1000
192.168.0.0/24 dev eno1 proto kernel scope link src 192.168.0.246 metric 100
192.168.0.0/24 dev wlp4s0 proto kernel scope link src 192.168.0.213 metric 600
Это может затруднить отладку, если у меня возникнут проблемы с подключением ;)
И я пока не знаю, как сохранить конфигурацию при перезагрузках, особенно в сочетании с сетевым менеджером.