大佬教程收集整理的这篇文章主要介绍了Linux上的负载均衡和NAT多个ISP连接,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我的设置是这样的 –
eth0(192.168.0.0/24) – 本地网络
eth1(192.168.1.0/24) – ISP#1
eth2(192.168.2.0/24) – ISP#2
我的本地网络通过eth0连接到此服务器,该框是LAN中所有计算机的DHCP服务器和网关.
服务器需要在两个ISP之间进行负载均衡,还需要进行NAT-ing.
我已按照lartc.org的路由指示进行操作,但仍需要正确执行NAT的说明.
任何帮助将不胜感激.
PS – 我知道pFsense但我需要使用Linux.
让我们假设一些事情:
LAN:eth0:192.168.0.1/24
ISP1:eth1:192.168.1.1/24,网关:192.168.1.2/24
ISP2:eth2:192.168.2.1/24,网关:192.168.2.2/24
所以这是我将如何使用iptables方法:
路线表
首先编辑/ etc / iproute2 / rt_tables以在路由表编号和ISP名称之间添加映射
... 10 ISP1 20 ISP2 ...
因此,表10和20分别用于ISP1和ISP2.我需要使用此代码片段(使用hxxp://linux-ip.net/html/adv-multi-internet.html)从主表的路径填充这些表.
ip route show table main | grep -Ev '^default' \ | while read ROUTE ; do ip route add table ISP1 $ROUTE done
ip route add default via 192.168.1.2 table ISP1
为ISP2做同样的事情
iptables的
好的,现在我使用iptables将数据包均匀分配到每个路由表.有关如何在这里找到这项工作的更多信息(http://www.diegolima.org/wordpress/?p=36)和这里(http://home.regit.org/?page_id=7)
# iptables -t mangle -A PRERoutING -j CONNMARK --restore-mark # iptables -t mangle -A PRERoutING -m mark ! --mark 0 -j ACCEPT # iptables -t mangle -A PRERoutING -j MARK --set-mark 10 # iptables -t mangle -A PRERoutING -m statistic --mode random --probability 0.5 -j MARK --set-mark 20 # iptables -t mangle -A PRERoutING -j CONNMARK --save-mark
NAT
NAT很简单:
# iptables -t nat -A POSTRoutING -o eth1 -j MASQUERADE # iptables -t nat -A POSTRoutING -o eth2 -j MASQUERADE
以上是大佬教程为你收集整理的Linux上的负载均衡和NAT多个ISP连接全部内容,希望文章能够帮你解决Linux上的负载均衡和NAT多个ISP连接所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。