利用LVS+keepalived的主从模式实现http的高可用性

实验前提:
1、本次实验作者使用的是RHEL5.8的32位系统平台。
2、实验所需软件为ipvsadm、keepalived、httpd
3、每个节点对应的ip地址如下:
direct1   192.168.108.199
direct2   192.168.108.201
realserver1  192.168.108.202
realserver2  192.168.108.150
VIP    192.168.108.100

实验拓扑如下:

wKioL1UFi5Pj4gRuAACck0M2hr0262.jpg


安装ipvsadm
在keepalived的配置文件中有一部分是关于LVS的配置,这部分配置在keepalived脚本启动后会作为参数传递给ipvsadm,ipvsadm从而会自动生成相关的IPVS规则。ipvsadm需要在两个direct上都安装
#yum -y  install  ipvsadm


安装keepalived
在这里使用编译的方式进行安装keepalived,软件下载地址http://www.keepalived.org/download.html
keepalived需要在前端2个direct上都安装

#tar xf keepalived-1.2.13.tar.gz
#cd keepalived-1.2.13
#./configure --prefix=/
#make && make install

如果在安装keepalived时出现如下错误,只需要在编译时,添加--disable-fwmark参数即可
checking for nl_socket_modify_cb in -lnl... no
configure: WARNING: keepalived will be built without libnl support.
checking for kernel version... 2.6.18
checking for IPVS syncd support... yes
checking for kernel macvlan support... no
checking whether SO_MARK is declared... no
configure: error: No SO_MARK declaration in headers


编辑配置文件/etc/keepalived.conf
global_defs {
   notification_email {
 root@localhost
   }
   notification_email_from xsl@localhost
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id LVS_DIRECT1
}

vrrp_instance VI_1 {
    state MASTER
    interface eth0
    virtual_router_id 88
    priority 100
    advert_int 2
    authentication {
        auth_type PASS
        auth_pass suiji
    }
    virtual_ipaddress {
        192.168.108.100
    }
}

virtual_server 192.168.108.100 80 {
    delay_loop 6
    lb_algo rr
    lb_kind DR
    persistence_timeout 0
    protocol TCP

    real_server 192.168.108.150 80 {
        weight 1
        HTTP_GET {
            url {
              path /www/xsl.com/index.html
            }
            connect_timeout 3
            nb_get_retry 2
            delay_before_retry 2
        }
    }
  
  
    real_server 192.168.108.202 80 {
        weight 1
        HTTP_GET {
            url {
               path /www/xsl.com/index.html
            }
            connect_timeout 3
            nb_get_retry 2
            delay_before_retry 2
        }
    }
}
编辑好配置文件后,可以将这个文件复制到另一个direct节点,另一个节点必须事先创建好/etc/keepalived目录
#scp /etc/keepalived/keepalived.conf   direct2:/etc/keepalived
然后在direct2上修改state为BACKUP,priority为90即可


#chkconfig  --add  keepalived
#chkconfig  keepalived  on


接在在这两个direct上启动keepalived服务
#service  keepalived start

当keepalived启动完成之后,可以检查虚拟IP地址是否已经生产,且虚拟IP地址位于MASTER上。
由于在配置文件中将direct1设置为MASTER,因此,只需要在direct上执行如下命令,即可检查配置是否成功
#ip addr show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast qlen 1000
    link/ether 00:0c:29:ed:fa:67 brd ff:ff:ff:ff:ff:ff
    inet 192.168.108.199/24 brd 192.168.108.255 scope global eth0
    inet 192.168.108.100/32 scope global eth0
    inet6 fe80::20c:29ff:feed:fa67/64 scope link
       valid_lft forever preferred_lft forever

需要说明的是虚拟ip地址是配置在接口上的,作为这个接口的第二地址,因此,使用ifconfig命令是看不出来的。

 

测试VIP漂移过程
当direct1发生故障时,测试VIP是否会漂移到direct2上去。
可以在direct1上执行如下命令来模拟direct1发生故障:
#service keepalived stop

执行命令完成之后,再在direct2上执行如下命令:
#ip addr show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast qlen 1000
    link/ether 00:0c:29:4f:f1:6a brd ff:ff:ff:ff:ff:ff
    inet 192.168.108.201/24 brd 192.168.108.255 scope global eth0
    inet 192.168.108.100/32 scope global eth0
    inet6 fe80::20c:29ff:fe4f:f16a/64 scope link
说明,当direct1发生故障时,VIP会立即漂移到direct2上去

其实配置到这里,keepalived的高可用功能已经实现了,接下来需要配置的是与lvs有关的内容


realserver上的配置   
安装httpd服务
在两个realserver上安装httpd服务
#yum -y install httpd

#service httpd start


安装完成后,最好是编辑一下每个realserver上的httpd默认根路径下的文件,即/var/www/html/index.html文件,使得2个文件保持不一致。方便后续测试。
然后在本机测试一下,看http服务是否可以正常访问,如果可以正常访问,则继续下面的操作。

将http服务设置为开机自启动。需要在两个realserver上都执行
#chkconfig  httpd on

在两个realserver上配置VIP,配置VIP的命令如下:
# echo 1 > /proc/sys/net/ipv4/conf/eth0/arp_ignore
# echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
# echo 2 > /proc/sys/net/ipv4/conf/eth0/arp_announce
# echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce
#ifconfig lo:0 192.168.108.100 broadcast 192.168.108.100 netmask 255.255.255.255 up
#route add -host 192.168.108.100 dev lo:0

在MASTER上查看IPVS规则是否生成
#ipvsadm -L -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.108.100:80 rr
  -> 192.168.108.202:80           Route   1      0          0        
  -> 192.168.108.150:80           Route   1      0          0
 
测试一
在浏览器上面输入http://192.168.108.100,然后再观察页面的内容

wKiom1UFisPAk31jAAEC9Av6iPo721.jpg


然后再次刷新页面,观察页面的内容

 wKioL1UFi_ryNAUEAAETBPeLoeM182.jpg

从上面测试知道,LVS的负载均衡功能已经实现。

 

测试二
当direct1发生故障时,direct1上的IPVS规则应该会被删除。
在direct1上执行如下命令用来模拟MASTER发生故障
#service keepalived stop
执行完成以后,分别在direct1和direct2上执行如下命令,来观察各个direc上的IPVS规则:
#ipvsadm  -L -n 
执行完成后,就会发现direct1上面的规则没有了。这里就不截图了。


测试三
当后端的realserver发生故障或运行在realserver上的服务发生故障时,则与这个realserver相关的IPVS规则会被删除。
如在realserver1上执行如下命令,来模拟httpd服务发生故障
#service httpd stop
然后再在作为MASTER上的服务器上查看IPVS规则,使用如下命令即可查看IPVS规则,这里我的direct2是作为MASTER。
#ipvsadm -L -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.108.100:80 rr
  -> 192.168.108.150:80           Route   1      0          0     
 看看,与realserver1相关的IPVS规则被删除了,说明测试成功。


其实,实验做到这里来,一个LVS+keepalived来实现web服务的高可用集群基本成功了。只是,对于这个实验仍然有许多不足之处,比如:
1、如果后端的realserver都发生故障,则前端的direct将无法响应客户端的请求,因此,会出现客户端打不开页面的情况,因此,在这种情况下,我们最好是返回一个提示信息给用户(如网站正在维护,请您稍后在浏览),这样给用户的感觉就比较直观。
2、其中在整个实验过程中,我们实现MASTER/BACKUP切换的主要是通过停止keepalived服务来进行的,那如何通过脚本来完成模式切换功能呢?
3、当VRRP切换事务发生时,如何发送警告给指定的管理员?

4、当keepalived与nginx或haproxy实现高可用时,如果nginx或haproxy服务本身不可用时,此时仍然需要实现主从切换,虽然MASTER服务器虽然可以正常工作,但是不能对外提供服务,这也是不允许的?该过程如何实现?


补充一
当后端的realserver都出现故障时,如何返回一个提示信息给用户?
配置步骤:
1、需要在所有的direct上安装httpd服务并将其设置为开机自启动,如:
#yum  -y  install  httpd
#chkconfig httpd  on


2、修改httpd服务默认根路径下的文件index.html的内容
echo  "Site is down for maintenance, please wait while browsing"  >  /www/xsl.com/index.html
说明:这里我采用的基于虚拟主机的httpd服务,因此,根路径可能不一样。如果是基于中心主机来配置的httpd服务,那么它的默认根路径下的文件为/var/www/html/index.html,即修改这个文件中的内容即可。


3、在所有的direct上启动httpd服务
#service httpd start

4、修改配置文件,需要在所有的direct上做修改
#vim  /etc/keepalived/keepalived.conf
需要在virtual_server 192.168.108.100 80 { }中添加一样这样的信息
sorry_server 127.0.0.1 80

如:
virtual_server 192.168.108.100 80 {
    delay_loop 6
    lb_algo rr
    lb_kind DR
    persistence_timeout 0
    protocol TCP
    sorry_server 127.0.0.1 80
 ...
}


4、模拟所有的realserver都down掉,如下命令需要在所有的realserver上执行
#service httpd  stop

5、测试
在浏览器上面输入http://192.168.108.100,观察网页的内容

wKiom1UFiy-xJME7AAEM-uowd6U224.jpg


发现网页的内容就是我们刚刚添加的内容。说明当所有的realserver都挂掉之后,访问的httpd服务是MASTER上的httpd服务,本地的httpd服务将返回本地页面中的内容给用户,该页面主要提供警示信息。


 

补充二、通过自写监测脚本来实现MASTER/BACKUP的切换
1、在所有的direct的配置文件/etc/keepalived/keepalived.conf添加如下配置:
vrrp_script chk_httpd_down {
        scripts "[[ -f /etc/keepalived/down ]] && exit 1 || exit 0"   这个表示要执行的命令或脚本
        interval 2    每个2秒检测一次
        weight 20     检测失败后,本节点的priority值会响应减少20
        fall 2        如果检测2次都失败了,则认为失败
        rise 1        如果检测一次成功,则认为是成功了。
}

脚本对好了之后,还需要在实例中调用。下面这段配置需要添加到实例配置下
track_script {
        chk_httpd_down
}


整个步骤如下:
vrrp_script chk_httpd_down {
        script "[[ -f /etc/keepalived/down ]] && exit 1 || exit 0 "
        interval 2  每隔2秒检查一下该文件是否存在
        weight -20  上述脚本如果执行失败(即状态码返回1),则优先级减20
        fall 2      连续检查2次都失败了,则最终认为失败了
        rise 1      连续检查1次成功了,则认为成功了。
}

vrrp_instance VI_1 {
    state MASTER
    interface eth0
    virtual_router_id 88
    priority 100
    advert_int 2
    authentication {
        auth_type PASS
        auth_pass suiji
    }
    virtual_ipaddress {
        192.168.108.100
    }
    track_script {
        chk_httpd_down
    }
}

 

上述添加的内容的意思是:只要在/etc/keepalived/目录下存在down这个文件,则MASTER就会切换成BACKUP。

 

3、测试

在当前MASTER节点上的/etc/keepalived/目录下创建down文件,观察此时节点的状态,此时你会发现,VIP已经飘逸到之前的BACKUP上去了。此时此刻该节点的状态为BACKUP。

 

补充三、当VRRP切换事务发生时,如何发送警告给指定的管理员?
在所有的direct上修改配置文件,并添加如下配置
    notify_master  "/etc/keepalived/notify.sh master"
    notify_backup  "/etc/keepalived/notify.sh backup"
    notify_fault  "/etc/keepalived/notify.sh fault"

这段配置是配置在vrrp_instance VI_1 {}实例中的


编写通知脚本
#vim  notify.sh

通知脚本如下:
#vim notify.sh
#!/bin/bash

#author:xsl
#description: An example of notify script
#

vip=192.168.108.100
contact='root@localhost'

notify() {
 mailsubjiect="`hostname` is to be $1 ,$vip floating"    #这里是邮件的主题
 mailbody="`date '+%F %H:%M:%S'`:vrrp transition,`hostname` changed to be $1 "
 echo $mailbody | mail -s "$mailsubject" $contact
}

case $1 in
master)
 notify master
 /etc/rc.d/init.d/haproxy start
 exit 0
 ;;
backup)
 notify backup
 /etc/rc.d/init.d/haproxy stop
 exit 0
 ;;
fault)
 notify fault

 /etc/rc.d/init.d/haproxy stop
 exit 0
 ;;
*)
 echo "usage:`basename $0` {master|backup|fault}"
 exit 1
 ;;
esac

 

给脚本加执行权限
#chmod +x notify.sh

 

然后将其复制一份传给direct2
#scp  /etc/keepalived/notify.sh  direct2:/etc/keepalived/

 

测试,在direct1节点上添加down文件
#touch  /etc/keepalived/down

 

查看虚拟IP地址是否还位于direct1上
#ip addr show


查看ipvs规则是否已被删除
#ipvsadm -L  -n


如果虚拟ip地址不存在了,则表示操作都成功了。一旦发生主从切换,root用户应该可以收到相关的邮件信息了。 

 

四、当keepalived与nginx或haproxy实现高可用时,如果nginx或haproxy服务本身不可用,如何实现主从切换?

其实这个过程和之前自写脚本完成MASTER/BACKUP切换过程是一样的。以haproxy为例,其配置如下:

vrrp_script haproxy_check {

        script "killall -0 haproxy" //这个命令用来测试haproxy这个进程是否存在,不会真正执行

        interval 2

        weight -2

}

track_script {

        haproxy_check

}


你可能感兴趣的:(LVS+keepalived,keepalived的主从模式)