У меня есть 2 интернет-канала, использующие 2 ADSL-маршрутизатора, и мне нужно предоставить доступ в Интернет для сети 192.168.0.0/24.
Мне нужно маршрутизировать исходящий трафик на основе номера порта, протокола,… с помощью iproute2 и iptables на маршрутизаторе Linux.
Это моя сеть:
(ISP-1) (ISP-2)
Dynamic public IP Dynamic public IP
| |
+---------------+ +---------------+
|ADSL Router (1)| |ADSL Router (2)|
+---------------+ +---------------+
| |
192.168.1.1 192.168.2.1
| |
| |
| |
| +------------------+ |
| | | |
192.168.1.2 --|eth1 eth2|-- 192.168.2.2
| |
| Linux Router |
| |
| eth0 |
+------------------+
|
192.168.0.1
|
|
Local Network:
192.168.0.0/24
Я использую следующий сценарий для настройки конфигурации сети на маршрутизаторе Linux:
#!/bin/bash
echo 1 >| /proc/sys/net/ipv4/ip_forward
echo 0 >| /proc/sys/net/ipv4/conf/all/rp_filter
# flush all iptables entries
iptables -t filter -F
iptables -t filter -X
iptables -t nat -F
iptables -t nat -X
iptables -t mangle -F
iptables -t mangle -X
iptables -t filter -P INPUT ACCEPT
iptables -t filter -P OUTPUT ACCEPT
iptables -t filter -P FORWARD ACCEPT
# marking packets
iptables -t mangle -A PREROUTING -i eth0 -p icmp -j MARK --set-mark 1
iptables -t mangle -A PREROUTING -i eth0 -p udp -j MARK --set-mark 1
iptables -t mangle -A PREROUTING -i eth0 -p tcp -j MARK --set-mark 2
# create routing tables and default routes
echo '1 ISP1' >> /etc/iproute2/rt_tables
echo '2 ISP2' >> /etc/iproute2/rt_tables
ip route add default via 192.168.1.1 dev eth1 table ISP1
ip route add default via 192.168.2.1 dev eth2 table ISP2
# routing based on previous marks
ip rule add fwmark 1 table ISP1
ip rule add fwmark 2 table ISP2
ip route flush cache
# NAT
iptables -t nat -A POSTROUTING -o eth1 -j MASQUERADE
iptables -t nat -A POSTROUTING -o eth2 -j MASQUERADE
Проблема в том, что я не могу подключиться к Интернету из сети 192.168.0.0/24.
Когда я пингую из этой сети на удаленный сервер, я вижу (используя Wireshark) ответы, возвращающиеся с удаленного сервера на eth1 маршрутизатора Linux, но они не достигают eth0.
Пожалуйста помоги. И заранее спасибо.
(РЕДАКТИРОВАТЬ)
Я пытался устранить эту странную проблему в течение недели.
Вывод команд устранения неполадок:
ip rule
0: from all lookup local
32764: from all fwmark 0x1 lookup ISP1
32765: from all fwmark 0x2 lookup ISP2
32766: from all lookup main
32767: from all lookup default
ip route show table ISP1
default via 192.168.1.1 dev eth1
ip route show table ISP2
default via 192.168.2.1 dev eth2
ip route show table main
192.168.2.0/24 dev eth2 proto kernel scope link src 192.168.2.2
192.168.1.0/24 dev eth1 proto kernel scope link src 192.168.1.2
192.168.0.0/24 dev eth0 proto kernel scope link src 192.168.0.1
169.254.0.0/16 dev eth0 scope link metric 1000
default via 192.168.1.1 dev eth1 metric 100
Я могу частично решить эту проблему, набрав следующие команды:
ip rule del fwmark 1 table ISP1
ip rule del fwmark 2 table ISP2
ip rule add from 192.168.0.0/24 table ISP1
Итак, я получаю весь трафик из локальной сети, правильно маршрутизируемый через канал ISP1, и все компьютеры получают доступ в Интернет.
Но меня интересует маршрутизация по меткам пакетов.
После долгой тяжелой работы я наконец нашел, в чем проблема.
На самом деле это не проблема маршрутизации, сценарий правильный, но чего-то не хватает.
Для отключения rp_filter этой команды недостаточно:
echo 0 >| /proc/sys/net/ipv4/conf/all/rp_filter
Таким образом, трафик, возвращающийся из Интернета, был сброшен на eth1 и eth2.
Когда я явно отключил rp_filter для обоих интерфейсов, добавив следующие команды:
echo 0 >| /proc/sys/net/ipv4/conf/eth1/rp_filter
echo 0 >| /proc/sys/net/ipv4/conf/eth2/rp_filter
Проблема была решена, и у меня все работает отлично.
Доказательство того, что учебники и документация по Linux не всегда являются законченными.
пожалуйста посмотрите. похоже, ваша проблема. http://www.slashroot.in/linux-kernel-rpfilter-settings-reverse-path-filtering
Если трафик возвращается к маршрутизатору, но не выходит снова, то проблема в вашей таблице маршрутизации, в каком-то правиле iptables или вы неправильно читаете wirehark. Существует не так много вариантов того, что могло бы остановить пакеты от выхода из системы.