On 8/21/06, Martijn Lievaart <m@xxxxxxx> wrote:
<citaat van="Gavin White"> > Hello, > > I would like to use iptables SNAT/DNAT to provide load balancing for > an inbound web service. The service is sticky, that is to say, users > must be redirected to the same machine during a user session, which > can span several TCP sessions. > > One simple way to do this would be by redirecting incoming connections > based on their source IP address. Since addresses might not be evenly > distributed through the address space, and many customers might be > concentrated in particular regions, I would like to specify a filter > using the last octet, ie. *.*.*.0-127 redirects to server A, and > *.*.*.128-255 redirects to server B. I would also be happy creating > 255 rules if a last - octet range is not possible. I think this will do the trick. -i $EXT -s 0.0.0.0/0.0.0.128 -j SNAT $A -i $EXT -j SNAT $B
This approach works perfectly, thank you. Gavin
> Does anyone have any suggestions on how to do this, or other, more > sensible approaches to sticky load balancling? I think you could the same with the nth and recent matches to achieve better load balancing, but it would be tricky (and not persistent across firewall reloads). Something along these lines: -i $EXT -j LOADBALANCE LOADBALANCE chain: -m recent -name loadbalA -rcheck -update -j SNAT $A -m recent -name loadbalB -rcheck -update -j SNAT $B -m nth --every 2 -m recent -name loadbalA -set -j SNAT $A -m recent -name loadbalB -set -j SNAT $B For true load balancing (taking the load of the webservers into account) you'll need something else, iptables alone cannot do that. HTH, M4