[LARTC] Two outbound internet links, using one network interface

Zoilo Gomez zoilo at xs4all.nl
Sun Oct 8 12:14:11 CEST 2006


Dashamir Hoxha wrote:

> Hi,
>
> I am trying to categorize the network traffic and to send it out 
> across two different providers.
> For this I mark the packets in the firewall (in the PREROUTING chain 
> of table mangle),
> and then use another routing table for the marked packets, which has a 
> different gateway
> from the main routing table. Basicaly I am following the cookbook 
> example in this page:
> http://linux-ip.net/html/adv-multi-internet.html
> with some small changes and modifications.
>
> The most important difference is that I am trying to use just one 
> external network interface,
> which is connected through a hub/switch  to both of the  ISP links. I 
> add two different IPs
> to this interface, corresponding to each providers network. Then the 
> masquerading is done
> with a rule like this:
>
> # iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE 
> instead of:
>
> # iptables -t nat -A POSTROUTING -o eth4 -j SNAT --to-source 67.17.28.12
> # iptables -t nat -A POSTROUTING -o eth1 -j SNAT --to-source 
> 205.254.211.179
>

How about using iproute2 (instead of MASQ / SNAT rule):

=> ip route add 192.168.10.0/24 dev eth0 src 192.168.10.1
=> ip route add 192.168.100.0/24 dev eth0 src 192.168.100.1


> For the traffic that is generated in the LAN behind the box, it works, 
> but for the
> traffic that is generated in the localhost (routing box), it does not 
> work.
> Indeed, it cannot possibly work for the localhost with a setup like 
> this (with only
> one external interface). As it can be seen in this document:
> http://www.faqs.org/docs/iptables/traversingoftables.html
> (Table 3-2. Source local host)
> routing decision happens before the packet enters the chains of the 
> iptables
> (the chain PREROUTING is not tranversed in this case).
>
> This is not a big problem (it is not so important that the traffic of 
> the routing box
> be categorized as well), but trying to solve it, I came up with 
> another solution,
> which seems simpler.The idea is to use something like this:
>
> --------------------------------------------------------------------------------- 
>
> IPT=/sbin/iptables
> PORT_LIST="22 53"
> GATEWAY1=192.168.10.1
> GATEWAY2=192.168.100.1
>
> for PORT in $PORT_LIST
> do
>  $IPT -t nat -A POSTROUTING -o eth0 \
>               -p tcp --dport $PORT -j SNAT --to-source $GATEWAY2
> done
>
> $IPT  -t nat -A POSTROUTING -o eth0 -j SNAT --to-source $GATEWAY1
> ----------------------------------------------------------------------------- 
>

> I have not tested it yet but I don't see why it should not work.
>
> Also, I have seen somewhere that using two IPs on the same interface 
> may be risky
> (may have security implications), but I don't see what they can be. If 
> somebody has
> any idea of them and how to avoid them, please let me know. E.g. I 
> have heard about
> "IP spoofing" but I don't understand what it is.


Using VLANs, you can separate the networks on the link level instead. 
This is the same (in software) as using 2 different LAN ports (in hardware).

Regards,

Z.



More information about the LARTC mailing list