服务器都使用2个网络地址,一个公网地址和一个私有网络地址。设置为公网ip的网络接口连接在一个交换机,设置为私有网络ip的网络接另外一个交换机,处于安全和网络带宽考虑,网络存储设备和数据库只使用私有网络地址。
用户----LVS-DR---->WEB1---- MYSQL
????????????? ---->WEB2----
真实ip地址(RIP):LVS-DR 220.202.254.2?
?????????? WEB1?? 220.202.254.20?? xx:192.168.88.1
?????????? WEB2?? 220.202.254.21?? xx:192.168.88.2
?????????? MYSQL?????????????????? xx:192.168.88.3
虚拟ip地址(VIP) WEB虚拟地址(vip1) 220.202.254.1
我的系统都是linux as4 u6? (2.6.9-5.EL)
[root@TestAs4 ~]# lsmod |grep ip_vs
ip_vs_wlc?????????????? 1857? 1?
ip_vs????????????????? 86433? 3 ip_vs_wlc
[root@TestAs4 ipvsadm-1.24]# modprobe ip_vs? #加载ip_vs
#!/bin/bash
RIP1=220.202.254.20
RIP2=220.202.254.21
?
VIP1=220.202.254.1
?
/etc/rc.d/init.d/functions
?
case "$1" in
?
start)
echo " start LVS of DirectorServer"
?
# set the Virtual IP Address and sysctl parameter
/sbin/ifconfig eth0:0 $VIP1 broadcast $VIP1 netmask 255.255.255.255 up
#/sbin/ifconfig eth0:1 $VIP2 broadcast $VIP2 netmask 255.255.255.255 up
/sbin/route add -host $VIP1 dev eth0:0
#/sbin/route add -host $VIP2 dev eth0:1
echo "1" >/proc/sys/net/ipv4/ip_forward
?
#Clear IPVS table
/sbin/ipvsadm -C
?
#set LVS
#Web Apache
/sbin/ipvsadm -A -t $VIP1:80 -s wlc -p 120
/sbin/ipvsadm -a -t $VIP1:80 -r $RIP1:80 -g
/sbin/ipvsadm -a -t $VIP1:80 -r $RIP2:80 -g
?
?
#Run LVS
/sbin/ipvsadm
;;
stop)
echo "close LVS Directorserver"
echo "0" >/proc/sys/net/ipv4/ip_forward
/sbin/ipvsadm -C
/sbin/ifconfig eth0:0 down
;;
*)
echo "Usage: $0 {start|stop}"
exit 1
esac
为什么要这样呢?因为有若干机器要使用同一个ip地址,用本身做广播地址和把子网掩码设成4个255就不会造成ip地址冲突了,否则lvs将不能正常转发访问请求。
有2个方法检验LVS/DR是否正常运行了:(1)查看内核是否列出ip_vs模块;(2)直接运行ipvsadm –l看输出是否有转发规则。
真实服务器配置虚拟ip地址。LVS可以把服务请求转发到各种各样的操作系统.
[root@cwmtest1 bin]# more lvs
#!/bin/bash
#description:start realserver
#chkconfig?
VIP1=220.202.254.1
/etc/rc.d/init.d/functions
case "$1" in
start)
echo " start LVS of REALServer"
/sbin/ifconfig lo:0 $VIP1 broadcast $VIP1 netmask 255.255.255.255 up
echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce
echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
;;
stop)
/sbin/ifconfig lo:0 down
echo "close LVS Directorserver"
echo "0" >/proc/sys/net/ipv4/conf/lo/arp_ignore
echo "0" >/proc/sys/net/ipv4/conf/lo/arp_announce
echo "0" >/proc/sys/net/ipv4/conf/all/arp_ignore
echo "0" >/proc/sys/net/ipv4/conf/all/arp_announce
;;
*)
echo "Usage: $0 {start|stop}"
exit 1
esac