主从热备+负载均衡(LVS + keepalived)

链接:

https://www.cnblogs.com/youzhibing/p/5021224.html

码云(gitee):https://gitee.com/youzhibing

环境准备

本机 + virtualBox + 4台centOs虚拟机,如下图

主从热备+负载均衡(LVS + keepalived)_第1张图片

virtualBox安装以及CentOS安装这里就不再演示,大家自行搭建;本机在本次试验中扮演的角色就是客户端,起到一个发送请求的作用,两台CentOS做负载均衡服务器(一台为主机,一台为备机),另外两台作为真实的Web服务器(安装有tomcat)。

本次实验基于DR负载均衡模式(直接路由,旭龙兄的博客有讲解),设置一个VIP(Virtual IP)为192.168.1.200,用户只需要访问这个IP地址即可获得网页服务。其中,负载均衡主机为

192.168.1.114(master),备机为

192.168.1.112(brucelee)。Web服务器A为

192.168.1.111(youzhibing),Web服务器B为

192.168.1.115(youzhibing03),四台机器命名除了master

外都不太规范,但不影响实验。四台CentOS的防火墙都需要关

闭。利用Xshell链接CentOS,如下图

主从热备+负载均衡(LVS + keepalived)_第2张图片

配置两台web服务器

主从热备+负载均衡(LVS + keepalived)_第3张图片

和本地部署web项目一样,将myWeb部署到tomcat中,开启tomcat,宿主机访问(virtualBox安装linux,并搭建tomcat请点这),如下图

主从热备+负载均衡(LVS + keepalived)_第4张图片
主从热备+负载均衡(LVS + keepalived)_第5张图片

将这两台web服务器都配置成lvs的real server,编辑realserver脚本文件,进入指定文件夹:cd /etc/init.d/,编辑脚本文件:vim realserver,如下图

主从热备+负载均衡(LVS + keepalived)_第6张图片

/etc/init.d/realserver 内容如下

#vi /usr/local/sbin/realserver.sh

#!/bin/bash

# description: Config realserver lo and apply noarp

#Written by :NetSeek http://www.linuxtone.org

SNS_VIP=192.168.1.200

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

case"$1"in

start)

ifconfig lo:0$SNS_VIPnetmask 255.255.255.255 broadcast$SNS_VIP

/sbin/route add -host$SNS_VIPdev 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$SNS_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"

       ;;

*)

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

exit1

esac

exit0

保存脚本文件后更改该文件权限:chmod 755 realserver,开启realserver服务:service realserver start;

注意:配置real server是web服务器都需要配置的,有多少台就配置多少台!

配置负载服务器(master)

主从热备+负载均衡(LVS + keepalived)_第7张图片

安装Keepalived

yuminstall -y keepalived

在CentOS下,通过yum install命令可以很方便地安装软件包,但是前提是你的虚拟机要联网,若没有联网则先从有网的地方下载压缩包,然后拷贝或者上传到linux系统,再进行安装;

配置keepalived

①进入keepalived.conf所在目录:cd 

/etc/keepalived

②首先清除掉keepalived原有配置:>

keepalived.conf

③重新编辑keepalived配置文件:vi keepalived.conf

内容如下:

global_defs {

    notification_email {

[email protected]

    }

    notification_email_from [email protected]

smtp_server192.168.1.114

smtp_connection_timeout30

router_id LVS_MASTER# 设置lvs的id,在一个网络应该是唯一的

}

vrrp_instance VI_1 {

stateMASTER# 指定keepalived的角色,MASTER为主,BACKUP为备

interface eth0# 当前进行vrrp通讯的网络接口卡(当前centos的网卡)

virtual_router_id66# 虚拟路由编号,主从要一直

priority100# 优先级,数值越大,获取处理请求的优先级越高

advert_int1# 检查间隔,默认为1s(vrrp组播周期秒数)

    authentication {

        auth_type PASS

auth_pass1111

    }

    virtual_ipaddress {

192.168.1.200# 定义虚拟ip(VIP),可多设,每行一个

    }

}

# 定义对外提供的LVS的VIP以及port

virtual_server192.168.1.2008080{

delay_loop6# 设置健康检查时间,单位为秒

lb_algo wrr# 设置负载调度的算法为wrr

lb_kind DR# 设置lvs实现负载的机制,有NAT、TUN、DR三个模式

nat_mask255.255.255.0

persistence_timeout0# 同一IP 0秒内的请求都发到同个real server

    protocol TCP

real_server192.168.1.1118080{# 指定real server1的ip地址

weight3# 配置节点权值,数值越大权重越高

        TCP_CHECK {

connect_timeout10

nb_get_retry3

delay_before_retry3

        }

    }

real_server192.168.1.1158080{

weight3

        TCP_CHECK {

connect_timeout10

nb_get_retry3

delay_before_retry3

        }

    }

}    

配置负载服务器(slave)

和主负载服务器一样,先安装keepalived,然后编辑keepalived.conf,内容如下,与主负载服务器有些许差别

global_defs {

    notification_email {

[email protected]

    }

    notification_email_from [email protected]

smtp_server192.168.1.112

smtp_connection_timeout30

router_id LVS_BACKUP# 设置lvs的id,在一个网络应该是唯一的

}

vrrp_instance VI_1 {

stateBACKUP# 指定keepalived的角色,MASTER为主,BACKUP为备

interface eth0# 当前进行vrrp通讯的网络接口卡(当前进行vrrp通讯的网络接口卡)

virtual_router_id66# 虚拟路由编号,主从要一致

priority99# 优先级,数值越大,获取处理请求的优先级越高

advert_int1# 检查间隔,默认为1s(vrrp组播周期秒数)

    authentication {

        auth_type PASS

auth_pass1111

    }

    virtual_ipaddress {

192.168.1.200# 定义虚拟ip(VIP),可多设,每行一个

    }

}

# 定义对外提供的LVS的VIP以及port

virtual_server192.168.1.2008080{

delay_loop6# 设置健康检查时间,单位为秒

lb_algo wrr# 设置负载调度的算法为wrr

lb_kind DR# 设置lvs实现负载的机制,有NAT、TUN、DR三个模式

nat_mask255.255.255.0

persistence_timeout0# 同一IP 0秒内的请求都发到同个real server

    protocol TCP

real_server192.168.1.1118080{# 指定real server1的ip地址

weight3# 配置节点权值,数值越大权重越高

        TCP_CHECK {

connect_timeout10

nb_get_retry3

delay_before_retry3

        }

    }

real_server192.168.1.1158080{

weight3

        TCP_CHECK {

connect_timeout10

nb_get_retry3

delay_before_retry3

        }

    }

}    

启动keepalive服务,主从都要启动!

servicekeepalived start

如果所有的"代码主题"都不符合你的要求,你可以参考"一键排版"下的"代码块样式"自定义

效果展示

负载均衡演示

主从热备+负载均衡(LVS + keepalived)_第8张图片
主从热备+负载均衡(LVS + keepalived)_第9张图片

这里出现了问题,发现同一个浏览器一段时间内刷新,得到的结果是同一个,也就是说同一个ip某一段时间内的请求交给了同一台real server处理,用centos上的浏览器测试也是一段时间内的请求得到的是同一个结果,但是与宿主机却有所不同,比如宿主机得到的是相同的192.168.1.115,而centos上得到的却是192.168.1.111,,可明明我配置了persistence_timeout 0,找了不少资料,还是没能解决!希望知道的朋友可以不吝赐教,在评论区进行留言,谢谢了!

a.web服务器出现故障

192.168.1.115发生故障,关闭115也就是youzhibing03的tomcat服务

主从热备+负载均衡(LVS + keepalived)_第10张图片

那么宿主机与虚拟机上的结果都只有一个,都得到如下结果

主从热备+负载均衡(LVS + keepalived)_第11张图片

b.web服务器修复,重新启动115的tomcat服务

主从热备+负载均衡(LVS + keepalived)_第12张图片

宿主机得到如下结果

主从热备+负载均衡(LVS + keepalived)_第13张图片

可虚拟机上显示的却还是192.168.111的结果

主从热备演示

a、关闭主负载服务器的keepalived服务

主从热备+负载均衡(LVS + keepalived)_第14张图片

刷新页面,依然能得到如下结果

主从热备+负载均衡(LVS + keepalived)_第15张图片

那么也就说明从负载服务器(brucelee)接管了,我们来看下日志

主从热备+负载均衡(LVS + keepalived)_第16张图片
主从热备+负载均衡(LVS + keepalived)_第17张图片

发现从负载服务器确实接管了主负载服务器的任务

b.当之前的主负载服务器(master)修复后,日志文件如下

主从热备+负载均衡(LVS + keepalived)_第18张图片
主从热备+负载均衡(LVS + keepalived)_第19张图片

主负载服务器恢复后,从负载服务器让出位置,回到最初的主从状态了!

总结

主从热备+负载均衡(LVS + keepalived)_第20张图片

总的来说,最终的效果还是符合标题的,虽然在负载均衡那一块有些许疑问,好像没有达到负载均衡的目的,但是也确实只是好像,因为总体而言还是有负载均衡效果的,比如宿主机的得到的是115的结果,而虚拟机上的得到的是111的结果;

目前流行的LVS解决方案中,在Web服务器端也有采用了Nginx+Tomcat这样的搭配类型,静态文件和动态文件分开进行处理,也不失为一种有效的尝试。在以后的日子里,我会陆续进行实践,并分享给大家!

后话

主从热备+负载均衡(LVS + keepalived)_第21张图片

这篇博客其实周六就写好了,但是一直纠结负载均衡那个位置,迟迟没有发表出来,也是希望对自己和对大家负责吧;但是有好心不一定就有好的结果,查阅了不少资料,也进行了不少修改,可负载均衡的效果一直没有改变(不是没有哦!),离我预期的有些出入,虽然有出入,但我认为负载均衡的效果是存在的,只是与单个浏览器刷新而得到两个效果之间轮流切换有一些不同罢了!

另外提一点,如果大家想亲手实践下的话,我建议大家的硬件不要太低了,我的i7处理器 + 4G内存,运行主机 +4台虚拟机有点卡,建议大家内存上大点,最好8G以上;

最后强调一点:实践是检验真理的唯一标准! 有些许的冲动就赶快去实践!

源网络,版权归原创者所有。如有侵权烦请告知,我们会立即删除并表示歉意。谢谢。


了解更多技术,欢迎关注下方公众号

主从热备+负载均衡(LVS + keepalived)_第22张图片

你可能感兴趣的:(主从热备+负载均衡(LVS + keepalived))