<--目录-->

1)安装LVS和Keepalived

2)lvs脚文内容

3)keepalived配置文件内容



【安装LVS和Keepalived】

#安装lvs工具

yum -y install ipvsadm


#安装keepalived

yum -y install gcc kernel-devel openssl-devel popt-devel

tar zxf keepalived-1.2.13.tar.gz

cd keepalived-1.2.13

./configure

make && make install

cp /usr/local/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/

cp /usr/local/etc/sysconfig/keepalived /etc/sysconfig/

mkdir /etc/keepalived

cp /usr/local/etc/keepalived/keepalived.conf /etc/keepalived/

cp /usr/local/sbin/keepalived /usr/sbin/

chkconfig --add keepalived

chkconfig keepalived on


#更换keepalived文件

#lvs 更换keepalived配置文件即可,换配置文件后还需更改虚拟IP


#更换web服务器文件(法1)

#在两台需要负载均衡的web服务器更换sysctl.conf,添加ifcfg-lo:0,添加ifcfg-lo:0后还需更改虚拟IP,或直接添加lvs这个脚本亦可


#更换web服务器文件(法2)

#1)在两台需要负载均衡的web服务器/opt目录下直接添加lvs这个脚本即可

#2)设置开机启动

tail -1 /etc/rc.local

/opt/lvs start


#5)测试轮询访问

#for((i=1;i<11;i++));do curl http://虚拟IP;echo $i;sleep 2;echo; done



#注意:

#1、如lvs出现裂脑情况,则可能是防火墙、selinux没关,网络关闭了

#2、发现设置了DR模式,rr轮询的调度算法,但访问刷新还是访问同一台web,那是因为设置了会话保持时间,把#他注释掉即可



【lvs脚文内容】

#!/bin/bash

# Written by NetSeek

# description: Config realserver lo and apply noarp

WEB_VIP=192.168.2.100       #此处改为你设定的vip地址


. /etc/rc.d/init.d/functions


case "$1" in

start)

ifconfig lo:0 $WEB_VIP netmask 255.255.255.255 broadcast $WEB_VIP

/sbin/route add -host $WEB_VIP dev lo:0

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

sysctl -p >/dev/null 2>&1

echo "RealServer Start OK"


;;

stop)

ifconfig lo:0 down

route del $WEB_VIP >/dev/null 2>&1

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 "RealServer Stoped"

;;

status)

# Status of LVS-DR real server.

islothere=`/sbin/ifconfig lo:0 | grep $WEB_VIP`

isrothere=`netstat -rn | grep "lo:0" | grep $web_VIP`

if [ ! "$islothere" -o ! "isrothere" ];then

# Either the route or the lo:0 device

# not found.

echo "LVS-DR real server Stopped."

else

echo "LVS-DR Running."

fi

;;

*)

# Invalid entry.

echo "$0: Usage: $0 {start|status|stop}"

exit 1

;;

esac

exit 0



【keepalived配置文件内容】

! Configuration File for keepalived


global_defs {

   notification_email {

     acassen@firewall.loc

     failover@firewall.loc

     sysadmin@firewall.loc

   }

   notification_email_from Alexandre.Cassen@firewall.loc

   smtp_server 127.0.0.1

   smtp_connect_timeout 30

   router_id LVS_DEVEL

}


vrrp_instance VI_1 {

    state MASTER    #主为MASTER,备为BACKUP

    interface eth0

    virtual_router_id 51    

    priority 100   #主的优先级比较高,主为100,备为90

    advert_int 1

    authentication {

        auth_type PASS

        auth_pass 1111

    }

    virtual_ipaddress {

        192.168.2.100

    }

}


virtual_server 192.168.2.100 80 {

    delay_loop 6

    lb_algo rr

    lb_kind DR

    nat_mask 255.255.255.0

    #persistence_timeout 10

    protocol TCP


    real_server 192.168.2.3 80 {

        weight 1

TCP_CHECK {

            connect_timeout 3

            nb_get_retry 3

            delay_before_retry 3

        }

    }

    

    real_server 192.168.2.4 80 {

        weight 1

        TCP_CHECK {

            connect_timeout 3

            nb_get_retry 3

            delay_before_retry 3

        }

    }   

}


virtual_server 192.168.2.100 443 {

    delay_loop 6

    lb_algo rr

    lb_kind DR

    nat_mask 255.255.255.0

    #persistence_timeout 10

    protocol TCP


    real_server 192.168.2.3 443 {

        weight 1

TCP_CHECK {

            connect_timeout 3

            nb_get_retry 3

            delay_before_retry 3

        }

    }

    

    real_server 192.168.2.4 443 {

        weight 1

        TCP_CHECK {

            connect_timeout 3

            nb_get_retry 3

            delay_before_retry 3

        }

    }   

}