lvs+keep搭建高可用web服务

title: lvs+keep搭建高可用web服务
date: 2015-11-26 22:11:55
tags:

第一部分 概念

负载均衡

生产环境下必不可少的基础手段当前大部分互联网都使用了服务器集群系统,集群即将相同服务部署在多台服务器上构成一个集群整体对外提供服务,这些集群可以是web应用服务器,也可以是数据库服务器集群,还可以是分布式缓存服务器集群等

在实际应用中,在web服务器之前总会有一台负载均衡服务器,负载均衡设备的任务就是作为web服务器的流量入口,挑最合适的一台web服务器,将客户端的请求转发给它处理,以实现客户端到服务端的透明转发,最近几年很火的云计算以及分布式架构,本质上也是将后端服务器作为计算资源,存储资源,由某台管理服务器封装成一个服务对外提供,客户端不需要关系真正提供服务的是那台机器,就好像它面对的是一台近乎拥有无限能力的服务器,而本质上,真正提供服务器的是后端集群。

负载均衡类型

  • 硬件设备,如F5 功能强大、有厂家支持,价格昂贵
  • 开源软件,功能同样强大,免费、对运维人员要求较高,最著名的就是LVS (Linux virtual server)

LVS

LVS主要用于服务器集群的负载均衡。它工作在网络层,可以实现高性能,高可用的服务器集群技术。它廉价,可把许多低性能的服务器组合在一起形成一个超级服务器。它易用,配置非常简单,且有多种负载均衡的方法。它稳定可靠,即使在集群的服务器中某台服务器无法正常工作,也不影响整体效果。另外可扩展性也非常好

LVS的体系结构

一、 使用LVS的服务器集群系统有三个部分组成

  1. 最前端的负载均衡层,用load balancer表示
  2. 中间的服务器集群层,用server array表示
    • 最底端的数据共享存储层,用shared storage表示在用户看来,所有内部应用的是透明的,用户只是在使用一个虚拟服务器提供的高性能服务。

      二、 LVS负载均衡机制
  3. LVS是四层负载均衡,也就是说建立在OSI模型中的第四层—传输层之上,传输层上有我们熟悉的TCP/UDP,LVS支持TCP/UDP负载均衡,因为LVS是四层负载均衡,因此它相对于其它负载均衡的解决办法,比如DNS域名轮流解析、引用负载的调度、客户端的调度等,它的效率是非常高的。
  4. LVS的转发主要是通过修改IP地址(NAT模式,分为源地址修改SNAT和目标地址修改DNAT)、修改目标MAC(DR)模式来实现的。
  5. NAT模式:网络地址转换
    • NAT(network address translation)是一种外网和内网地址映射的技术,NAT模式下,网络数据报文都要经过LVS的处理。LVS需要作为RS(real server)的网关。当包达到LVS时,LVS做目标地址转换(DNAT),将目标IP改为RS的IP。RS接收到包后,仿佛是客户端直接发给它一样,RS处理完,返回响应时,源IP是RS IP ,目标IP是客户端的IP。这时RS的包通过网关(LVS)中转,LVS会做源地址转换(SNAT),将包的源地址改为VIP,这样,这个包对客户端看起来就仿佛是LVS直接返回给它的。客户端无法感知到后端RS的存在
  6. DR模式:直接路由
  7. DR模式下需要LVS和RS集群绑定同一个VIP(RS将通过VIP帮点在loopback实现),但与NAT不同点在于:请求由LVS接受,由真是提供服务器的服务器直接返回给用户,返回的时候不经过LVS。详细来看,一个请求过来时,LVS只需要将网络帧的MAC地址修改为某一台RS的MAC,该包就会被转发到相应的RS处理,注意此时的源IP和目标IP都没变,LVS只是做了一下移花接木。RS收到LVS转发来的包时,链路层发现MAC地址是自己的,到上面的网络层,发现IP也是自己的,于是这个包就被合法的接受,RS感知不到前面有LVS的存在,而当RS返回响应时,只需要向源IP(即用户的IP)返回即可,不再经过LVS。
  8. DR负载均衡模式数据分发过程中不需要修改IP地址,只修改MAC地址,由于实际处理请求的真实物理IO地址和数据请求的IP地址一致,所以不需要负载均衡服务器进行地址转换,可将响应数据包直接返回给用户浏览器,避免负载均衡服务器网卡带宽成为瓶颈,因此DR模式具有较好的性能,它是目前大型网站使用最广泛的负载均衡手段。

第二部分 实践

1.总览

因为条件限制,所有整个架构通过虚拟机搭建
客户端:虚拟机宿主机:192.168.31.100
VIP:192.168.31.111
虚机系统均为:centos6.5
LVS:-master:192.168.31.121
LVS-slvae:192.168.31.122
web-01:192.168.31.131
web-02:192.168.31.132


本次基于Parallels desktop搭建的四台Linux(cents6.5)系统所构成的一个服务器集群,其中两台负载均衡服务器(一台主机,一台为备机),另外两台作为真实的web服务器(向外提供HTTP服务,这里仅仅使用了centos自带的http服务,没有安装其它web服务器,本次实验基于DR负载均衡模式,设置了一个VIP为192.168.31.111,用户只需访问这个IP即可获取网页,其中负载均衡主机为192.168.31.121,备机为192.168.31.122.web服务器A为192.168.31.131,web服务器B为192.168.31.132。

2.准备工作

以下工作针对所有服务器,也就是在四台服务器都要配置:

  • 绑定静态地址:命令模式下可以执行setup命令进行静态IP地址的设置,配置完成后重启即可
  • 设置主机名:修改配置文件中的额主机名,vim /etc/sysconfig/network 永久修改主机名,完成后重启生效
  • IP地址和主机名的绑定:vim /etc/hosts 增加如 192.168.31.121 lvs-master 192.168.31.122 lvs-slave 192.168.31.131 lvs-webserver1 192.168.31.132 lvs-webserver2 保存后退出,验证 ping las-master
  • 关闭防火墙 service iptables stop 关闭开机启动chkconfig iptables off

配置web服务器

以下操作要在两台web服务器中进行,不要再负载均衡服务器中进行

  • 开启httpd服务并设置为开机启动 service http start && chkconfig http on

  • 在httpd默认web目录(/var/www/html)中创建页面index.html 内容分别为>

    hello web-01

    hello web-02

    ,用于区别两台web服务器

  • 显示如下,比较简陋

  • 编辑realserver脚本文件 vim /etc/init.d/realserver:http://7xolbq.com1.z0.glb.clouddn.com/realserver

realserver附件

    • 然后赋权 chmod 755 /etc/init.d/realserver 另外启动的适合提示权限问题,顺便也加下权限 chmod 755 /etc/init.d/functions
  • 开启realserver服务:service realserver start

配置主负载服务器

安装keepalived相关包

  • yum install keepalived -y
  • 进入keepalived配置目录 cd /etc/keepalived/
  • 备份一下配置文件,然后重新配置 cp keepalived.conf keepalived.conf.bak && vim keepaliced.conf keepalived.conf的配置文件:http://7xolbq.com1.z0.glb.clouddn.com/keepalived.conf

  • 开启keepalived服务 并设置开机启动 service keepalived start && chkconfig keepalived on

配置从负载服务器

从负载均和服务器和住负载均衡服务器大致相同,只是在keepalived的配置文件需要修改以下两处:

  • 将state由MASTER改为BACKUP

  • 将priority由100改为99 具体如下

  • 至此所有配置完成

第三部分 测试验证

start

在浏览器输入VIP 反复刷新 两个页面在轮询

测试keepalived高可用

这时候模拟web01故障 关闭web-01的http service httpd stop 这时候应该只能出现web-02的页面

测试符合预料
然后恢复web-01 service http start 这时候应该恢复之前轮询的状态


再次符合我们的猜想


接着测试keepalived主从

这时候模拟LVS-01故障 关闭LVS-01的keepalived service keepaliced stop 这时候应该依然可以提供负载均衡服务

没有问题,负载均衡没有受到影响,然后恢复LVS-01的keepalived service keepalived start


负载均衡依然可用

试验就此结束

最后 总结

LVS是目前广为采用的软件负载均衡解决方案,在一些大型企业级系统及互联网系统中应用。本次,简单地了解了一下LVS,并在Linux下搭建了一个小小的测试环境,借助Keepalived实现了一个最小化的负载均衡测试环境。LVS是一个可以工作在网络第四层的负载均衡软件,因此它相对于Nginx一类工作在第七层的负载均衡软件有着无可比拟的性能优势,而且它还是我国的章文嵩博士(现在阿里的副总裁,淘宝的技术专家)作为创始人发起的,现已经成为Linux内核的组成部分。

参考:非洲蚂蚁的博客 http://ixdba.blog.51cto.com/2895551/552947

posted on 2016-05-14 14:42  扶朕起来,朕还能送  阅读(920)  评论(0编辑  收藏  举报

导航