联系我们

地址:黑龙江省哈尔滨市南岗区文库街16号智力大厦208室
邮编:150040
业务咨询办理:
——座机:0451-89060603
——手机:013945010420
电话总机:0451-86230075 86230073
传真:拨通总机转608
网站教学 QQ:499485031
网站教学 QQ:498760590
业务咨询 QQ:470030788
[ MSN:ourservice@hotmail.com ]

文章内容
Linux环境下多链路负载均衡
2008年05月10日 11:02    点击数:         
打印本页 收藏 关闭 【字号
导读:

  1.1----------------------Multipath Routing

  网上关于multipath routing 的文章已经很多了,在此我只想指出应用multipath routing时必须安装以下两个补丁后重新编译内核(至少RH8的ip route 包需要这两个补丁)  (自助建站系统免费下载就到山石科技网站)

  Name:iproute2-2.4.7-now-ss020116-try.tar.gz

  URL:ftp://ftp.inr.ac.ru/ip-routing/

  Function:解决dead link 问题

  Name:equalize_2.4.18.patch

  URL:http://trash.net/~kaber/equalize/

  Function:即使没有这个补丁, ip route 也有equalize参数,但不起作用ping 不通。

  1.2.Multipath routing 的问题。

  同一个ISP的多链路得到的gateway ip 可能是一样的,这种情况下multipath routing不能工作。另外据说multipath routing只能对管理outgoing package

  2.1.---------------------Policy routing .

  原理:

  把客户端的ip随机的分成N组,每一组对应一条链路,分组由服务器端的shell script完成。(本文不涉及拨号软件的安装和配置,请参照其它文章。)

  测试环境:

  RH8。不需要其它的补丁。

  安全问题:

  由于运行改程序的主机,没有默认路由。外部主机根本无法访问,彻底防止黑客攻击。

  缺点:

  不是真正的负载均衡,一个IP地址不可能占用第二个链路的带宽。

  链路冗余:

  当一条链路断掉后可以在/etc/ppp/ip-down.local脚本,把失效的路由转换到另一条线路。

  该脚本中$1为接口名,如ppp0

  ip route add default dev ppp1 table 201

  脚本:

  -------------------------------------------------

  #标识为fwmark 1的ip地址属于table 201地址池。

  ip rule add fwmark 1 table 201

  ip rule add fwmark 2 table 202

  --------------------------------------------------

  #修改/etc/rc.local

  echo " enabling forwarding.."

  echo "1" > /proc/sys/net/ipv4/ip_forward

  echo " enabling DynamicAddr.."

  echo "1" > /proc/sys/net/ipv4/ip_dynaddr

  insmod ip_nat_ftp

  insmod ip_nat_irc

  insmod iptable_nat

  insmod ip_conntrack_irc

  insmod ip_conntrack_ftp

  iptables -t nat -A POSTROUTING -o ppp0 -j MASQUERADE

  iptables -t nat -A POSTROUTING -o ppp1 -j MASQUERADE

  #201地址池的客户端分配给ppp0

  ip route add default dev ppp0 table 201

  ip route add default dev ppp1 table 202

  #不要接受ISP的默认网关,否则在此之前删除ISP的默认网关。

  ----------------------------------------------------------

  #ip分发主程序,根据实际情况,需改动Linenum即链路的个数,

  #和cat pool1 pool2 >pooltmp

  #由telnet客户端启动该程序,使用nohup TheScriptName &,防止程序意外中止.

  #!/bin/bash

  LineNum=2

  ME=$( basename $0 )

  # Evaluate load on diffrent lines ,return the less busy one.

  #

  function EvaLoad ()

  {

  Fwmark=1

  Cnt=1

  Line=$(wc -l pool1 |awk {print $1})

  while [ $Cnt -lt $LineNum ]

  do

  Cnt=$( expr $Cnt + 1 )

  LineN=$(wc -l pool$Cnt |awk {print $1})

  if [ $Line -gt $LineN ]

  then

  Line=$LineN

  Fwmark=$Cnt

  fi

  done

  }

  #Start script

  function DispatcherStart ()

  {

  #Initialize ip address pool automatically

  Cnt=1

  while [ $Cnt -le $LineNum ]

  do

  cat /dev/null>pool$Cnt

  Cnt=$( expr $Cnt + 1 )

  done

  iptables -t mangle -F

  #Contact ARP table to find new clients

  while :

  do

  grep [0-9] /proc/net/arp |awk {print $1} >iparp

  cat pool1 pool2 >pooltmp

  cat iparp |while read ClientIp

  do

  grep -w "$ClientIp" pooltmp>/dev/null

  if [ $? -ne 1 ]

  then

  continue

  fi

  EvaLoad

  iptables -t mangle -A PREROUTING -s $ClientIp/32 -j MARK --set-mark $Fwmark

  echo $ClientIp >> pool$Fwmark

  done

  sleep 30

  done

  }

  #

  #------------------Main script

  #

  #

  case "$1" in

  start)

  echo -e "Bringing up Dispatcher Program "

  echo ""

  DispatcherStart

  ;;

  stop)

  echo -e "Shutting down Dispatcher program "

  kill -9 $( ps -ef|grep "$ME" |awk {print $2} )

  if [ $? = 0 ] ;then

  echo success

  else

  echo failure

  fi

  echo ""

  ;;

  restart)

  $0 stop

  $0 start

  ;;

  *)

  echo "Usage: $ME {start&|stop|restart}"

  exit 1

  esac

  exit 0

 

相关文章


Copyright © 2000 - 2011┊Sumly Soft, All Rights Reserved┊三雷科技 版权所有┊Email:harbin@126.com┊公司简介

地址:黑龙江省哈尔滨市南岗区文库街16号智力大厦208室┊邮编:150040

业务咨询办理:0451-89060603、013945010420┊电话总机:0451-86230075 86230073┊传真:拨通总机转608

[网站教学 QQ:499485031┊网站教学498760590┊业务咨询470030788]┊[ MSN:ourservice@hotmail.com ]

黑B2-20040341

全球最专业的多语言大型商业社区系统 - 三雷软件
本商业网站系统由哈尔滨三雷科技有限公司开发提供
powered by sumly! cms 6.0.0 © 2000 - 2008 30t.com inc.
the most professional multilanguage commercial community developer - sumly