LVS

一,LVS功能详解

1.1 LVS(Linux Virtual Server)介绍

LVS是Linux Virtual Server 的简写(也叫作IPVS),意即Linux虚拟服务器,是一个虚拟的服务器集群系统,能够在UNIX/LINUX平台下实现负载均衡集群功能。css

1.2 企业网站LVS集群架构图

QQ截图20170807112955.png-667.2kB

1.3 IPVS软件工做层次图

图片1.png-22.6kB

从上图咱们看出,LVS负载均衡调度技术是在Linux内核中实现的,所以,被称之为Linux虚拟服务器(Linux Virtual Server)。咱们使用该软件配置LVS时候,不能直接配置内核中的ipbs,而须要使用ipvs管理工具ipvsadm进行管理,或者经过Keepalived软件直接管理ipvs。html

1.4 LVS体系结构与工做原理简单描述

  • LVS集群负载均衡器接受服务的全部入站客户端计算机请求,并根据调度算法决定哪一个集群节点应该处理回复请求。负载均衡器(简称LB)有时也被称为LVS Director(简称Director)。
  • LVS虚拟服务器的体系结构以下图所示,一组服务器经过高速的局域网或者地理分布的广域网相互链接,在他们的前端有一个负载调度器(Load Balancer)。 负载调度器能无缝地将网络请求调度到真实服务器上,从而使得服务器集群的结构对客户是透明的,客户访问集群系统提供的网络服务就像访问一台高性能,高可用的服务器同样。客户程序不受服务器集群的影响不须要做任何修改。系统的伸缩性经过在服务集群中透明地加入和删除一个节点来达到,经过检测节点或服务进程故障和正确地重置系统达到高可用性。因为咱们的负载调度技术是在Linux内核中实现的,咱们称之为Linux虚拟服务器(Linux Virtual Server)。

1.5 LVS 基本工做过程图

LVS基本工做过程以下图所示:前端

QQ截图20170807214557.png-289.1kB

为了方便你们探讨LVS技术,LVS社区提供了一个命名的约定,内容以下表:linux

名称 缩写 说明
虚拟IP VIP VIP为Director用于向客户端计算机提供服务的IP地址。好比:www.yunjisuan.com域名就要解析到vip上提供服务
真实IP地址 RIP 在集群下面节点上使用的IP地址,物理IP地址
Dirctor的IP地址 DIP Director用于链接内外网络的IP地址,物理网卡上的IP地址。是负载均衡器上的IP
客户端主机IP地址 CIP 客户端用户计算机请求集群服务器的IP地址,该地址用做发送给集群的请求的源IP地址

LVS集群内部的节点称为真实服务器(Real Server),也叫作集群节点。请求集群服务的计算机称为客户端计算机。
与计算机一般在网上交换数据包的方式相同,客户端计算机,Director和真实服务器使用IP地址彼此进行通讯。
不一样架构角色命名状况以下图:nginx

QQ截图20170807215600.png-310.1kB

1.6 LVS集群的3种常见工做模式介绍与原理讲解

IP虚拟服务器软件IPVSweb

  • 在调度器的实现技术中,IP负载均衡技术是效率最高的。在已有的IP负载均衡技术中有经过网络地址转换(Network Address Translation)将一组服务器构成一个高性能的,高可用的虚拟服务器,咱们称之为VS/NAT技术(Virtual Server via Network Address Translation),大多数商业化的IP负载均衡调度器产品都是使用NAT的方法,如Cisco的额LocalDirector,F5,Netscaler的Big/IP和Alteon的ACEDirector。
  • 在分析VS/NAT 的缺点和网络服务的非对称性的基础上,咱们提出经过IP隧道实现虚拟服务器的方法VS/TUN(Virtual Server via IP Tunneling)和经过直接路由实现虚拟服务器的方法VS/DR(Virtual Server via Direct Routing),他们能够极大地提升系统的伸缩性。因此,IPVS软件实现了这三种IP负载均衡技术。淘宝开源的模式FULLNAT.

LVS的四种工做模式算法

  1. NAT(Network Address Translation)
  2. TUN(Tunneling)
  3. DR(Direct Routing)
  4. FULLNAT(Full Network Address Translation)

1.6.1 NAT模式-网络地址转换<==收费站模式(了解便可)

Virtual Server via Network Address Translation(VS/NAT)数据库

调度时:目的IP改为RIP(DNAT)
返回时:源IP改为VIP(SNAT)apache

QQ截图20180203195841.png-39.9kB

QQ截图20180203195908.png-51.6kB

NAT模式特色小结:windows

  1. NAT技术将请求的报文(DNAT)和响应的报文(SNAT),经过调度器地址重写而后在转发发给内部的服务器,报文返回时在改写成原来的用户请求的地址。
  2. 只须要在调度器LB上配置WAN公网IP便可,调度器也要有私有LAN IP和内部RS节点通讯。
  3. 每台内部RS节点的网关地址,必需要配成调度器LB的私有LAN内物理网卡地址(LDIP),这样才能确保数据报文返回时仍然通过调度器LB。
  4. 因为请求与响应的数据报文都通过调度器LB,所以,网站访问量大时调度器LB有较大瓶颈,通常要求最多10-20台节点。
  5. NAT模式支持对IP及端口的转换,即用户请求10.0.0.1:80,能够经过调度器转换到RS节点的10.0.0.2:8080(DR和TUN模式不具有的)
  6. 全部NAT内部RS节点只须要配置私有LAN IP便可。
  7. 因为数据包来回都须要通过调度器,所以,要开启内核转发net.ipv4.ip_forward=1,固然也包括iptables防火墙的forward功能(DR和TUN模式不须要)。

1.6.2 TUN模式-(了解便可)

QQ截图20180203200015.png-42.1kB

增长一个IP头部。经过IP隧道进行通讯(能够跨网段找到RS节点)

TUN模式特色小结:

  1. 负载均衡器经过把请求的报文经过IP隧道的方式转发至真实服务器,而真实服务器将响应处理后直接返回给客户端用户。
  2. 因为真实服务器将响应处理后的报文直接返回给客户端用户,所以,最好RS有一个外网IP地址,这样效率才会更高。理论上:只要能出网便可,无需外网IP地址。
  3. 因为调度器LB只处理入站请求的报文。所以,此集群系统的吞吐量能够提升10倍以上,但隧道模式也会带来必定得系统开销。TUN模式适合LAN/WAN。
  4. TUN模式的LAN环境转发不如DR模式效率高,并且还要考虑系统对IP隧道的支持问题。
  5. 全部的RS服务器都要绑定VIP,抑制ARP,配置复杂。
  6. LAN环境通常多采用DR模式,WAN环境能够用TUN模式,可是当前在WAN环境下,请求转发更多的被haproxy/nginx/DNS调度等代理取代。所以,TUN模式在国内公司实际应用的已经不多。跨机房应用要么拉光纤成局域网,要么DNS调度,底层数据还得同步。
  7. 直接对外的访问业务,例如:Web服务作RS节点,最好用公网IP地址。不直接对外的业务,例如:MySQL,存储系统RS节点,最好用内部IP地址。

1.6.3 DR模式-直接路由模式(重点)

Virtual Server via Direct Routing(VS/DR)

VS/DR模式是经过改写请求报文的目标MAC地址,将请求发给真实服务器的,而真实服务器将响应后的处理结果直接返回给客户端用户。同VS/TUN技术同样,VS/DR技术可极大地提升集群系统的伸缩性。并且,这种DR模式没有IP隧道的开销,对集群中的真实服务器也没有必须支持IP隧道协议的要求,可是要求调度器LB与正式服务器RS节点都有一块网卡连在同一物理网段上,即必须在同一个局域网环境。

QQ截图20180203200058.png-45.3kB

只修改目标MAC地址,经过MAC找到RS节点(没法跨网段找到RS节点)

DR模式特色小结:

  1. 经过在调度器LB上修改数据包的目的MAC地址实现转发。(源IP地址仍然是CIP,目的IP地址仍然是VIP)
  2. 请求的报文通过调度器,而RS响应处理后的报文无需通过调度器LB,所以,并发访问量大时使用效率很高(和NAT模式相比)
  3. 因DR模式是经过MAC地址的改写机制实现的转发,所以,全部RS节点和调度器LB只能在一个局域网LAN中(缺点)
  4. RS节点的默认网关不须要是调度器LB的DIP,而直接是IDC机房分配的上级路由器的IP(这是RS带有外网IP地址的状况),理论讲:只要RS能够出网便可,不是必需要配置外网IP
  5. 因为DR模式的调度器仅进行了目的MAC地址的改写,所以,调度器LB没法改变请求的报文的目的端口(缺点)
  6. 当前,调度器LB支持几乎全部的UNIX,LINUX系统,但目前不支持WINDOWS系统。真实服务器RS节点能够是WINDOWS系统。
  7. 总的来讲DR模式效率很高,可是配置也较麻烦,所以,访问量不是特别大的公司能够用haproxy/nginx取代之。这符合运维的原则:简单,易用,高效。日2000W PV或并发请求1万如下均可以考虑用haproxy/nginx(LVS NAT模式)
  8. 直接对外的访问业务,例如:Web服务作RS节点,RS最好用公网IP地址。若是不直接对外的业务,例如:MySQl,存储系统RS节点,最好只用内部IP地址。

1.6.4 FULLNAT模式-(了解便可)

QQ截图20170809102737.png-158.7kB

QQ截图20170809104552.png-185.4kB

QQ截图20170809104638.png-190.8kB

淘宝的LVS应用模式

FULLANT特色:
1,源IP改为不一样的VIP和目的IP改为RIP
2,RS处理完毕返回时,返回给不一样的LVS调度器
3,全部LVS调度器之间经过session表进行Client Address的共享

1.7 LVS的调度算法

  • LVS的调度算法决定了如何在集群节点之间分布工做负荷。
  • 当Director调度器收到来自客户端计算机访问它的VIP上的集群服务的入站请求时,Director调度器必须决定哪一个集群节点应该处理请求。Director调度器可用于作出该决定的调度方法分红两个基本类别:
    固定调度方法:rr,wrr,dh,sh
    动态调度算法:wlc,lc,lblc,lblcr,SED,NQ

10种调度算法见以下表格(rr,wrr,wlc重点):

算法 说明
rr 轮循调度,它将请求依次分配不一样的RS节点,也就是在RS节点中均摊请求。这种算法简单,可是只适合于RS节点处理性能相差不大的状况
wrr 权重轮循,它将依据不一样RS节点的权值分配任务。权值较高的RS将优先得到任务,而且分配到的链接数将比权值较低的RS节点更多。相同权值的RS获得相同数目的链接数
dh 目的地址哈希调度,以目的地址为关键字查找一个静态hash表来得到须要的RS
sh 源地址哈希调度,以源地址为关键字查找一个静态hash表来得到须要的RS
wlc 加权最小链接数调度,实际链接数除以权值,最小的RS做为分配的RS
lc 最小链接数调度,链接数最小的RS做为分配的RS
lblc 基于地址的最小链接数调度,未来自同一目的地址的请求分配给同一台RS节点
lblcr 基于地址带重复最小链接数调度。(略)
SED 最短的指望的延迟(不成熟)
NQ 最小队列调度(不成熟)

1.8 LVS的调度算法的生产环境选型

  • [x] :通常的网络服务,如Http,Mail,MySQL等,经常使用的LVS调度算法为:
    • 基本轮叫调度rr算法
    • 加权最小链接调度wlc
    • 加权轮叫调度wrr算法
  • [x] :基于局部性的最少连接LBLC和带复制的基于局部性最少连接LBLCR主要适用于Web Cache和Db Cache集群,可是咱们不多这样用。(都是一致性哈希算法)
  • [x] :源地址散列调度SH和目标地址散列调度DH能够结合使用在防火墙集群中,它们能够保证整个系统的惟一出入口。
  • [x] :最短预期延时调度SED和不排队调度NQ主要是对处理时间相对比较长的网络服务。

实际使用中,这些算法的适用范围不限于这些。咱们最好参考内核中的链接调度算法的实现原理,根据具体业务需求合理的选型。

1.9 LVS集群的特色

LVS集群的特色能够归结以下:

(1)功能:

实现三种IP负载均衡技术和10种链接调度算法的IPVS软件。在IPVS内部实现上,采用了高效的Hash函数和垃圾回收机制,能正确处理所调度报文相关的ICMP消息(有些商品化的系统反而不能)。虚拟服务的设置数目没有限制,每一个虚拟服务都有本身的服务器集。它支持持久的虚拟服务(如HTTP Cookie 和HTTPS等须要该功能的支持),并提供详尽的统计数据,如链接的处理速率和报文的流量等。针对大规模拒绝服务(Deny of service)攻击,实现了三种防卫策略:有基于内容请求分发的应用层交换软件KTCPVS,它也是在Linux内核中实现。有相关的集群管理软件对资源进行检测,能及时将故障屏蔽,实现系统的高可用性。主,从调度器能周期性地进行状态同步,从而实现更高的可用性。

(2)适用性

1)后端真实服务器可运行任何支持TCP/IP的操做系统,包括Linux,各类Unix(如FreeBSD,Sun Solaris,HP Unix等),Mac/OS和windows NT/2000等。

2)负载均衡调度器LB可以支持绝大多数的TCP和UDP协议:

协议 内容
TCP HTTP,FTP,PROXY,SMTP,POP3,IMAP4,DNS,LDAP,HTTPS,SSMTP等
UDP DNS,NTP,TCP,视频,音频流播放协议等

无需对客户机和服务做任何修改,可适用大多数Internet服务。

3)调度器自己当前不支持windows系统。支持大多数的Linux和UINIX系统。

(3)性能

LVS服务器集群系统具备良好的伸缩性,可支持几百万个并发链接。配置100M网卡,采用VS/TUN或VS/DR调度技术,集群系统的吞吐量可高达1Gbits/s;如配置千兆网卡,则系统的最大吞吐量可接近10Gbits/s

(4)可靠性

LVS服务器集群软件已经在不少大型的,关键性的站点获得很好的应用,因此它的可靠性在真实应用获得很好的证明。

(5)软件许可证

LVS集群软件是按GPL(GNU Public License)许可证发行的自由软件,这意味着你能够获得软件的源代码,有权对其进行修改,但必须保证你的修改也是以GPL方式发行。

1.10 LVS的官方中文阅读资料

标题 地址
LVS项目介绍 http://www.linuxvirtualserver.org/zh/lvs1.html
LVS集群的体系结构 http://www.linuxvirtualserver.org/zh/lvs2.html
LVS集群中的IP负载均衡技术 http://www.linuxvirtualserver.org/zh/lvs3.html
LVS集群的负载调度 http://www.linuxvirtualserver.org/zh/lvs4.html

二,手动实现LVS的负载均衡功能(DR模式)

2.1 安装LVS软件

2.1.1 LVS应用场景说明

1)数据库及memcache等对内业务的负载均衡环境

管理IP地址 角色 备注
192.168.0.210 LVS调度器(Director) 对外提供服务的VIP为192.168.0.240
192.168.0.223 RS1(真实服务器)  
192.168.0.224 RS2(真实服务器)  

特别提示:上面的环境为内部环境的负载均衡模式,即LVS服务是对内部业务的,如数据库及memcache等的负载均衡

2)web服务或web cache等负载均衡环境

外部IP地址 内部IP地址 角色 备注
192.168.200.210 192.168.0.210 LVS调度器(Director) 对外提供服务的VIP为192.168.0.240
192.168.200.223 192.168.0.223 RS1(真实服务器)  
192.168.200.224 192.168.0.224 RS2(真实服务器)  

提示:
这个表格通常是提供Web或Web cache负载均衡的状况,此种状况特色为双网卡环境。这里把192.168.0.0/24假设为内网卡,192.168.200.0/24假设为外网卡。

2.1.2 实验一律述(同窗们开始作)

QQ截图20170810205508.png-22.4kB

内部IP(eth0) 外部IP(eth1) 角色 备注
192.168.0.210 LVS负载均衡器 VIP:192.168.0.240网关为:192.168.0.100
192.168.0.223 Web01节点 网关为:192.168.0.100
192.168.0.224 Web02节点 网关为:192.168.0.100
192.168.0.220 内网客户端 网关为:192.168.0.100
192.168.200.200 外网客户端 不配网关
192.168.0.100 192.168.200.100 网关型防火墙 双网卡均无网关

2.1.3 两台Web配置简单的http服务

为了方便,咱们能够用yum简单装一个apache提供httpd服务进行测试,过程略。

2.1.4 开始安装LVS

如下的安装都是在LVS LB 192.168.0.210上

1)下载相关软件包

wget http://www.linuxvirtualserver.org/software/kernel-2.6/ipvsadm-1.24.tar.gz # <===适合5.x系统 wget http://www.linuxvirtualserver.org/software/kernel-2.6/ipvsadm-1.26.tar.gz # <===适合6.x系统 

2)安装准备命令

[root@lvs01 ~]# lsmod | grep ip_vs #查看linux内核是否有ipvs服务 [root@lvs01 ~]# uname -r #查看内核版本 2.6.32-431.el6.x86_64 [root@lvs01 ~]# cat /etc/redhat-release #查看系统版本 CentOS release 6.5 (Final) [root@lvs01 ~]# yum -y install kernel-devel #光盘安装 [root@lvs01 ~]# ls -ld /usr/src/kernels/2.6.32-431.el6.x86_64/ drwxr-xr-x. 2 root root 4096 Aug 9 19:28 /usr/src/kernels/2.6.32-431.el6.x86_64/ #安装完就会出现此目录 [root@lvs01 ~]# ln -s /usr/src/kernels/2.6.32-431.el6.x86_64/ /usr/src/linux #作一个软链接 [root@lvs01 ~]# ll -d /usr/src/linux/ drwxr-xr-x. 2 root root 4096 Aug 9 19:28 /usr/src/linux/ [root@lvs01 ~]# ll /usr/src/ total 8 drwxr-xr-x. 2 root root 4096 Sep 23 2011 debug drwxr-xr-x. 3 root root 4096 Aug 9 19:28 kernels lrwxrwxrwx. 1 root root 39 Aug 9 19:28 linux -> /usr/src/kernels/2.6.32-431.el6.x86_64/ [root@lvs01 ~]# 

特别注意:
此ln命令的连接路径要和uname -r输出结果内核版本对应,工做中若是作安装虚拟化可能有多个内核路径
若是没有/usr/src/kernels/2.6.32-431.el6.x86_64/路径,极可能是由于缺乏kernel-devel软件包。可经过yum进行安装
centos5.x版本不能用ipvs1.26

3)安装lvs命令:

[root@lvs01 ~]# yum -y install libnl* popt* #须要经过公网源安装 [root@lvs01 ~]# cd /usr/src/ipvsadm-1.26/ [root@lvs01 ipvsadm-1.26]# make #直接编译不须要./configure [root@lvs01 ipvsadm-1.26]# make install [root@lvs01 ~]# which ipvsadm /sbin/ipvsadm [root@lvs01 ~]# ipvsadm IP Virtual Server version 1.2.1 (size=4096) Prot LocalAddress:Port Scheduler Flags -> RemoteAddress:Port Forward Weight ActiveConn InActConn [root@lvs01 ~]# lsmod | grep ip_vs #执行完/sbin/ipvsadm就会有信息 ip_vs 125220 0 libcrc32c 1246 1 ip_vs ipv6 317340 270 ip_vs,ip6t_REJECT,nf_conntrack_ipv6,nf_defrag_ipv6 #==>出现这个内容就表示LVS已经安装好,并加载到了内核

LVS安装小结:
1,CentOS5.X安装lvs,使用1.24版本。
2,CentOS6.X安装lvs,使用1.26版本。
3,安装lvs后,要执行ipvsadm把ip_vs模块加载到内核。

2.2 手动配置LVS负载均衡服务

2.2.1 手工添加lvs转发

(1)配置LVS虚拟IP(VIP)

[root@lvs01 ~]# ifconfig eth0:0 192.168.0.240 broadcast 192.168.0.240 netmask 255.255.255.0 up [root@lvs01 ~]# ifconfig eth0:0 eth0:0 Link encap:Ethernet HWaddr 00:0C:29:D5:7F:9D inet addr:192.168.0.240 Bcast:192.168.0.240 Mask:255.255.255.255 UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1

(2)手工执行配置添加LVS服务并增长两台RS

[root@lvs01 ~]# ipvsadm -C #清空ipvs历史设置 [root@lvs01 ~]# ipvsadm --set 30 5 60 #设置超时时间(tcp tcpfin udp) [root@lvs01 ~]# ipvsadm -A -t 192.168.0.240:80 -s rr -p 20 #说明: -A:添加一个虚拟路由主机(LB) -t:指定虚拟路由主机的VIP地址和监听端口 -s:指定负载均衡算法 -p:指定会话保持时间 [root@lvs01 ~]# ipvsadm -a -t 192.168.0.240:80 -r 192.168.0.223:80 -g -w 1 [root@lvs01 ~]# ipvsadm -a -t 192.168.0.240:80 -r 192.168.0.224:80 -g -w 1 #说明: -a:添加RS节点 -t:指定虚拟路由主机的VIP地址和监听端口 -r:指定RS节点的RIP地址和监听端口 -g:指定DR模式 -w:指定权值

(3)查看lvs配置结果

[root@lvs01 ~]# 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.0.240:80 rr persistent 20 -> 192.168.0.223:80 Route 1 0 0 -> 192.168.0.224:80 Route 1 0 0 

(4)ipvs配置删除方法

[root@lvs01 ~]# #ipvsadm -D -t 192.168.0.240:80 -s rr #删除虚拟路由主机 [root@lvs01 ~]# #ipvsadm -d -t 192.168.0.240:80 -r 192.168.0.223:80 #删除RS节点

此时,能够打开浏览器访问http://192.168.0.240体验结果,若是没意外,是没法访问的。(RS将包丢弃了)

QQ截图20170810005652.png-434.1kB

2.2.2 手工在RS端绑定

#在Web01上操做 [root@web01 ~]# ifconfig lo:0 192.168.0.240/32 up #掩码必须设置32 [root@web01 ~]# ifconfig lo:0 lo:0 Link encap:Local Loopback inet addr:192.168.0.240 Mask:0.0.0.0 UP LOOPBACK RUNNING MTU:16436 Metric:1 #在Web02上操做 [root@web02 ~]# ifconfig lo:0 192.168.0.240/32 up #掩码必须设置32 [root@web02 ~]# ifconfig lo:0 lo:0 Link encap:Local Loopback inet addr:192.168.0.240 Mask:0.0.0.0 UP LOOPBACK RUNNING MTU:16436 Metric:1

2.2.3 浏览器测试LVS转发效果

QQ截图20170810010649.png-24.7kB

QQ截图20170810010717.png-25.3kB

注意:
在测试时候你会发现刷新看的都是同一个RS节点
这是由于浏览器的缓存问题
等一段时间之后,刷新就会从新负载均衡到新RS节点了

2.2.4 关于DR模式RS节点的ARP抑制的问题

QQ截图20170810005652.png-434.1kB

  • 由于在DR模式下,RS节点和LVS同处一个局域网网段内。
  • 当网关经过ARP广播试图获取VIP的MAC地址的时候
  • LVS和节点都会接收到ARP广播而且LVS和节点都绑定了192.168.0.240这个VIP,因此都会去响应网关的这个广播,致使冲突现象。
  • 所以,咱们须要对RS节点作抑制ARP广播的措施。
[root@web01 ~]# echo "1" > /proc/sys/net/ipv4/conf/lo/arp_ignore [root@web01 ~]# echo "2" > /proc/sys/net/ipv4/conf/lo/arp_announce [root@web01 ~]# echo "1" > /proc/sys/net/ipv4/conf/all/arp_ignore [root@web01 ~]# echo "2" > /proc/sys/net/ipv4/conf/all/arp_announce 

2.2.5 配置网关型防火墙

防火墙的双网卡都不要设置网关,由于本身的就网关

[root@localhost ~]# ip a 1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN 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 state UP qlen 1000 #内网网卡 link/ether 00:0c:29:ee:d3:15 brd ff:ff:ff:ff:ff:ff inet 192.168.0.100/24 brd 192.168.0.255 scope global eth0 inet6 fe80::20c:29ff:feee:d315/64 scope link valid_lft forever preferred_lft forever 3: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000 #外网网卡 link/ether 00:0c:29:ee:d3:1f brd ff:ff:ff:ff:ff:ff inet 192.168.200.100/24 brd 192.168.200.255 scope global eth1 inet6 fe80::20c:29ff:feee:d31f/64 scope link valid_lft forever preferred_lft forever [root@localhost ~]# route -n Kernel IP routing table Destination Gateway Genmask Flags Metric Ref Use Iface 192.168.0.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0 192.168.200.0 0.0.0.0 255.255.255.0 U 0 0 0 eth1 169.254.0.0 0.0.0.0 255.255.0.0 U 1002 0 0 eth0 169.254.0.0 0.0.0.0 255.255.0.0 U 1003 0 0 eth1 #防火墙不须要配置网关,所以没有默认路由信息 [root@localhost ~]# head /etc/sysctl.conf #开启网卡路由转发 # Kernel sysctl configuration file for Red Hat Linux # # For binary values, 0 is disabled, 1 is enabled. See sysctl(8) and # sysctl.conf(5) for more details. # Controls IP packet forwarding net.ipv4.ip_forward = 1 #修改成1 # Controls source route verification net.ipv4.conf.default.rp_filter = 1 [root@localhost ~]# sysctl -p #让配置即刻生效 net.ipv4.ip_forward = 1 net.ipv4.conf.default.rp_filter = 1 net.ipv4.conf.default.accept_source_route = 0 kernel.sysrq = 0 kernel.core_uses_pid = 1 net.ipv4.tcp_syncookies = 1 error: "net.bridge.bridge-nf-call-ip6tables" is an unknown key error: "net.bridge.bridge-nf-call-iptables" is an unknown key error: "net.bridge.bridge-nf-call-arptables" is an unknown key kernel.msgmnb = 65536 kernel.msgmax = 65536 kernel.shmmax = 68719476736 kernel.shmall = 4294967296

特别提示:
Web01,Web02,LVS负载均衡器,以及内网客户端均将网关设置成网关型防火墙的eth0:192.168.0.100

2.2.6 配置内网客户端

内网客户端用于模拟lvs应用于内网的负载均衡状况
好比lvs数据库读负载均衡,好比lvs memcached缓存组负载均衡
因为这类型的负载均衡请求都是由内网服务器发起,所以用内网客户端来模拟

#内网客户端访问测试

root@LanClient ~]# hostname -I
192.168.0.220 #内网客户端IP [root@LanClient ~]# route -n #默认路由为网关防火墙 Kernel IP routing table Destination Gateway Genmask Flags Metric Ref Use Iface 192.168.0.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0 169.254.0.0 0.0.0.0 255.255.0.0 U 1002 0 0 eth0 0.0.0.0 192.168.0.100 0.0.0.0 UG 0 0 0 eth0 [root@LanClient ~]# curl 192.168.0.240 192.168.0.224 bbs [root@LanClient ~]# curl 192.168.0.240 192.168.0.223 bbs [root@LanClient ~]# curl 192.168.0.240 192.168.0.224 bbs [root@LanClient ~]# curl 192.168.0.240 192.168.0.223 bbs #从上面能够看出,内网客户端模拟访问lvs负载均衡器,成功!

2.2.7 配置外网客户端

外网客户端模拟的是lvs转发外网用户访问需求给RS节点处理的状况
模拟外网客户端,要求客户端不能配置任何网关

QQ截图20170810213311.png-9kB

因为外网客户端要访问内网的LVS须要通过网关防火墙的跳转,所以须要在防火墙服务器上作iptables的DNAT和SNAT,配置以下:

[root@GATEWAY ~]# hostname -I 192.168.0.100(内网网卡) 192.168.200.100(外网网卡) [root@GATEWAY ~]# route -n Kernel IP routing table Destination Gateway Genmask Flags Metric Ref Use Iface 192.168.0.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0 192.168.200.0 0.0.0.0 255.255.255.0 U 0 0 0 eth1 169.254.0.0 0.0.0.0 255.255.0.0 U 1002 0 0 eth0 169.254.0.0 0.0.0.0 255.255.0.0 U 1003 0 0 eth1 [root@GATEWAY ~]# iptables -t nat -A PREROUTING -i eth1 -d 192.168.200.100 -p tcp --dport 80 -j DNAT --to-destination 192.168.0.240 [root@GATEWAY ~]# iptables -t nat -A POSTROUTING -s 192.168.0.0/24 -o eth1 -j SNAT --to-source 192.168.200.100 [root@GATEWAY ~]# iptables -t nat -L -nv Chain PREROUTING (policy ACCEPT 25 packets, 5251 bytes) pkts bytes target prot opt in out source destination 32 1920 DNAT tcp -- eth1 * 0.0.0.0/0 192.168.200.100 tcp dpt:80 to:192.168.0.240 Chain POSTROUTING (policy ACCEPT 53 packets, 3208 bytes) pkts bytes target prot opt in out source destination 0 0 SNAT all -- * eth1 192.168.0.0/24 0.0.0.0/0 to:192.168.200.100 Chain OUTPUT (policy ACCEPT 22 packets, 1348 bytes) pkts bytes target prot opt in out source destination [root@GATEWAY ~]# 

进行外网客户端访问LVS负载均衡器测试

QQ截图20170810214139.png-37.1kB

特别提示:
因为浏览器缓存及LVS默认会话保持等影响,我的简单的测试切换RS的概率要不少次而且间隔必定时间访问才行。尽量关闭浏览器换不一样的客户端IP来测试,效果更明显一些。用单机测试是有这种状况(负载均衡的算法倾向于一个客户端IP定向到一个后端服务器,以保持会话连贯性),若是用两三台机器去测试也许就不同。
在测试访问的同时能够经过ipvsadm -Lnc来查看访问结果,以下所示:

[root@lvs01 network-scripts]# ipvsadm -lnc IPVS connection entries pro expire state source virtual destination TCP 01:41 FIN_WAIT 192.168.0.220:59805 192.168.0.240:80 192.168.0.224:80 TCP 01:40 FIN_WAIT 192.168.0.220:59803 192.168.0.240:80 192.168.0.224:80 TCP 01:50 FIN_WAIT 192.168.200.200:34926 192.168.0.240:80 192.168.0.223:80 TCP 01:41 FIN_WAIT 192.168.0.220:59804 192.168.0.240:80 192.168.0.223:80 TCP 01:50 FIN_WAIT 192.168.200.200:34925 192.168.0.240:80 192.168.0.224:80 TCP 01:41 FIN_WAIT 192.168.0.220:59806 192.168.0.240:80 192.168.0.223:80 TCP 01:40 FIN_WAIT 192.168.0.220:59802 192.168.0.240:80 192.168.0.223:80 TCP 01:51 FIN_WAIT 192.168.200.200:34927 192.168.0.240:80 192.168.0.224:80 

2.3 arp抑制技术参数说明

  • [x] : arp_ignore-INTRGER
  • 定义对目标地址为本地IP的ARP询问不一样的应答模式
    • 0(默认值):回应任何网络接口上对任何本地IP地址的arp查询请求。
    • 1:只回答目标IP地址是来访网络接口本地地址的ARP查询请求
    • 2:只回答目标IP地址是来访网络接口本地地址的ARP查询请求,且来访IP必须在该网络接口的子网段内。
    • 3:不回应该网络界面的arp请求,而只对设置的惟一和链接地址作出回应。
    • 4-7:保留未使用
    • 8:不回应全部(本地地址)的arp查询。
  • [x] :arp_announce-INTEGER
  • 对网络接口上,本地IP地址的发出的,ARP回应,做出相应级别的限制:肯定不一样程度的限制,宣布对来自本地源IP地址发出Arp请求的接口。
    • 0(默认值):在任意网络接口(eth0,eth1,lo)上的任何本地地址
    • 1:尽可能避免不在该网络接口子网段的本地地址作出arp回应,当发起ARP请求的源IP地址是被设置应该经由路由达到此网络接口的时候颇有用。此时会检查来访IP是否为全部接口上的子网段内IP之一。若是该来访IP不属于各个网络接口上的子网段内,那么将采用级别2的方式来进行处理。
    • 2:对查询目标使用最适当的本地地址,在此模式下将忽略这个IP数据包的源地址并尝试选择能与该地址通讯的本地地址,首要是选择全部的网络接口的子网中外出访问子网中包含该目标IP地址的本地地址。若是没有合适的地址被发现,将选择当前的发送网络接口或其余的有可能接受到该ARP回应的网络接口来进行发送。限制了使用本地的vip地址做为优先的网络接口。

2.4 开发脚本配置LVS负载均衡器端

2.4.1 LVS负载均衡器端自动配置脚本:

[root@lvs01 scripts]# cat ipvs_server.sh #!/bin/bash # author:Mr.chen #LVS scripts . /etc/init.d/functions VIP=192.168.0.240 SUBNET="eth0:`echo $VIP | awk -F "." '{print $4}'`" PORT=80 RIP=( 192.168.0.223 192.168.0.224 ) function start(){ if [ `ifconfig | grep $VIP | wc -l` -ne 0 ];then stop fi ifconfig $SUBNET $VIP broadcast $VIP netmask 255.255.255.0 up ipvsadm -C ipvsadm --set 30 5 60 ipvsadm -A -t $VIP:$PORT -s rr -p 20 for ((i=0;i<${#RIP[*]};i++)) do ipvsadm -a -t $VIP:$PORT -r ${RIP[$i]} -g -w 1 done } function stop(){ ipvsadm -C if [ `ifconfig | grep $VIP | wc -l` -ne 0 ];then ifconfig $SUBNET down fi route del -host $VIP dev eth0 &>/dev/null } case "$1" in start) start echo "ipvs is started" ;; stop) stop echo "ipvs is stopped" ;; restart) stop echo "ipvs is stopped" start echo "ipvs is started" ;; *) echo "USAGE:$0 {start | stop | restart}" esac 

2.4.2 RS节点Web服务器端自动配置脚本

[root@web01 scripts]# cat rs_server.sh #!/bin/bash # author:Mr.chen # RS_sever scripts . /etc/rc.d/init.d/functions VIP=192.168.0.240 case "$1" in start) echo "start LVS of REALServer IP" interface="lo:`echo $VIP | awk -F "." '{print $4}'`" /sbin/ifconfig $interface $VIP broadcast $VIP netmask 255.255.255.255 up route add -host $VIP dev $interface 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) interface="lo:`echo $VIP | awk -F "." '{print $4}'`" /sbin/ifconfig $interface down echo "STOP LVS of REALServer IP" 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 

三,企业LVS负载均衡高可用最优方案(LVS+Keepalived)

3.1 实验二概述(同窗们开始作)

QQ截图20170811104939.png-22.8kB

内部IP(eth0) 外部IP(eth1) 角色 备注
192.168.0.210 LVS负载均衡器(主) VIP:192.168.0.240
192.168.0.211 LVS负载均衡器(备) VIP:192.168.0.240
192.168.0.223 Web01节点  
192.168.0.224 Web02节点  
192.168.0.220 内网客户端  

3.2 LVS负载均衡器主和备安装LVS软件

过程略

3.3 两台Web服务器安装Web服务

过程略

3.4 LVS负载均衡器主和备安装Keepalived软件

[root@lvs01 ~]# yum -y install keepalived #光盘安装便可

3.5 仅实现LVS负载均衡器主和备的keepalived高可用功能

LVS负载均衡器主的keepalived配置文件内容以下

[root@lvs01 ~]# sed -n '1,30p' /etc/keepalived/keepalived.conf ! Configuration File for keepalived global_defs { notification_email { 215379068@qq.com } notification_email_from yunjisuan smtp_server 127.0.0.1 smtp_connect_timeout 30 router_id LVS01 } vrrp_instance VI_1 { state MASTER interface eth0 virtual_router_id 55 priority 150 advert_int 1 authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.0.240/24 dev eth0 label eth0:240 } } 

LVS负载均衡器主的keepalived配置文件内容以下

[root@localhost ~]# sed -n '1,30p' /etc/keepalived/keepalived.conf ! Configuration File for keepalived global_defs { notification_email { 215379068@qq.com } notification_email_from yunjisuan smtp_server 127.0.0.1 smtp_connect_timeout 30 router_id LVS02 } vrrp_instance VI_1 { state BACKUP interface eth0 virtual_router_id 55 priority 100 advert_int 1 authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.0.240/24 dev eth0 label eth0:240 } } 

3.6 添加LVS的负载均衡规则

如下操做过程,在LVS主和备上彻底同样

[root@localhost ~]# ipvsadm -C [root@localhost ~]# ipvsadm -A -t 192.168.0.240:80 -s rr [root@localhost ~]# ipvsadm -a -t 192.168.0.240:80 -r 192.168.0.223:80 -g -w 1 [root@localhost ~]# ipvsadm -a -t 192.168.0.240:80 -r 192.168.0.224:80 -g -w 1 [root@localhost ~]# ipvsadm -Ln IP Virtual Server version 1.2.1 (size=4096) Prot LocalAddress:Port Scheduler Flags -> RemoteAddress:Port Forward Weight ActiveConn InActConn TCP 192.168.0.240:80 rr persistent 20 -> 192.168.0.223:80 Route 1 0 0 -> 192.168.0.224:80 Route 1 0 0 

3.7 启动LVS主和备的keepalived服务

#在LVS主上 [root@lvs01 ~]# /etc/init.d/keepalived start [root@lvs01 ~]# ifconfig eth0 Link encap:Ethernet HWaddr 00:0C:29:D5:7F:9D inet addr:192.168.0.210 Bcast:192.168.0.255 Mask:255.255.255.0 inet6 addr: fe80::20c:29ff:fed5:7f9d/64 Scope:Link UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:23567 errors:0 dropped:0 overruns:0 frame:0 TX packets:14635 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:2008524 (1.9 MiB) TX bytes:1746298 (1.6 MiB) eth0:240 Link encap:Ethernet HWaddr 00:0C:29:D5:7F:9D inet addr:192.168.0.240 Bcast:0.0.0.0 Mask:255.255.255.0 UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 lo Link encap:Local Loopback inet addr:127.0.0.1 Mask:255.0.0.0 inet6 addr: ::1/128 Scope:Host UP LOOPBACK RUNNING MTU:16436 Metric:1 RX packets:769 errors:0 dropped:0 overruns:0 frame:0 TX packets:769 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:0 RX bytes:56636 (55.3 KiB) TX bytes:56636 (55.3 KiB) #在LVS副上 [root@localhost ~]# /etc/init.d/keepalived start [root@localhost ~]# ifconfig eth0 Link encap:Ethernet HWaddr 00:0C:29:E7:06:1D inet addr:192.168.0.211 Bcast:192.168.0.255 Mask:255.255.255.0 inet6 addr: fe80::20c:29ff:fee7:61d/64 Scope:Link UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:14109 errors:0 dropped:0 overruns:0 frame:0 TX packets:4902 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:12683754 (12.0 MiB) TX bytes:553207 (540.2 KiB) lo Link encap:Local Loopback inet addr:127.0.0.1 Mask:255.0.0.0 inet6 addr: ::1/128 Scope:Host UP LOOPBACK RUNNING MTU:16436 Metric:1 RX packets:155 errors:0 dropped:0 overruns:0 frame:0 TX packets:155 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:0 RX bytes:11283 (11.0 KiB) TX bytes:11283 (11.0 KiB) #若是LVS副上没有VIP就对了。若是主副都有,那么请检查防火墙是否开启状态

3.8 内网客户端进行访问测试

#在内网客户端上进行访问测试
[root@LanClient ~]# curl 192.168.0.240 192.168.0.224 bbs [root@LanClient ~]# curl 192.168.0.240 192.168.0.223 bbs [root@LanClient ~]# curl 192.168.0.240 192.168.0.224 bbs [root@LanClient ~]# curl 192.168.0.240 192.168.0.223 bbs [root@LanClient ~]# curl 192.168.0.240 192.168.0.224 bbs [root@LanClient ~]# curl 192.168.0.240 192.168.0.223 bbs [root@LanClient ~]# curl 192.168.0.240 192.168.0.224 bbs #在LVS主上进行访问链接查询 [root@lvs01 ~]# ipvsadm -Lnc IPVS connection entries pro expire state source virtual destination TCP 00:01 FIN_WAIT 192.168.0.220:59887 192.168.0.240:80 192.168.0.223:80 TCP 00:01 FIN_WAIT 192.168.0.220:59889 192.168.0.240:80 192.168.0.223:80 TCP 00:01 FIN_WAIT 192.168.0.220:59888 192.168.0.240:80 192.168.0.224:80 TCP 00:00 FIN_WAIT 192.168.0.220:59886 192.168.0.240:80 192.168.0.224:80 #在LVS主上停掉keepalived服务 [root@lvs01 ~]# /etc/init.d/keepalived stop Stopping keepalived: [ OK ] [root@lvs01 ~]# ifconfig | grep eth0:240 #在LVS副上查看VIP [root@localhost ~]# ip a | grep eth0:240 inet 192.168.0.240/24 scope global secondary eth0:240 #再次在内网客户端上进行访问测试 [root@LanClient ~]# curl 192.168.0.240 192.168.0.223 bbs [root@LanClient ~]# curl 192.168.0.240 192.168.0.224 bbs [root@LanClient ~]# curl 192.168.0.240 192.168.0.223 bbs [root@LanClient ~]# curl 192.168.0.240 192.168.0.224 bbs [root@LanClient ~]# curl 192.168.0.240 192.168.0.223 bbs #在LVS副上进行访问链接查询 [root@localhost ~]# ipvsadm -Lnc IPVS connection entries pro expire state source virtual destination TCP 01:47 FIN_WAIT 192.168.0.220:59900 192.168.0.240:80 192.168.0.223:80 TCP 01:09 FIN_WAIT 192.168.0.220:59891 192.168.0.240:80 192.168.0.224:80 TCP 01:48 FIN_WAIT 192.168.0.220:59902 192.168.0.240:80 192.168.0.223:80 TCP 01:09 FIN_WAIT 192.168.0.220:59892 192.168.0.240:80 192.168.0.224:80 TCP 01:14 FIN_WAIT 192.168.0.220:59896 192.168.0.240:80 192.168.0.224:80 TCP 01:10 FIN_WAIT 192.168.0.220:59894 192.168.0.240:80 192.168.0.224:80 #开启LVS主上的keepalived服务 [root@lvs01 ~]# /etc/init.d/keepalived start [root@lvs01 ~]# ip a | grep eth0:240 inet 192.168.0.240/24 scope global secondary eth0:240 #查看LVS副上VIP资源是否释放 [root@localhost ~]# ip a | grep eth0:240 [root@localhost ~]# 

综上,至此基于LVS的keepalived高可用功能实验完毕

3.9 经过Keepalived对LVS进行管理的功能实现

[root@lvs01 ~]# cat /etc/keepalived/keepalived.conf ! Configuration File for keepalived global_defs { notification_email { 215379068@qq.com } notification_email_from yunjisuan smtp_server 127.0.0.1 smtp_connect_timeout 30 router_id LVS01 } vrrp_instance VI_1 { state MASTER interface eth0 virtual_router_id 55 priority 150 advert_int 1 authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.0.240/24 dev eth0 label eth0:240 } } virtual_server 192.168.0.240 80 { #虚拟主机VIP delay_loop 6 # lb_algo rr #算法 lb_kind DR #模式 nat_mask 255.255.255.0 #掩码 # persistence_timeout 50 #会话保持 protocol TCP #协议 real_server 192.168.0.223 80 { #RS节点 weight 1 #权重 TCP_CHECK { #节点健康检查 connect_timeout 8 #延迟超时时间 nb_get_retry 3 #重试次数 delay_before_retry 3 #延迟重试次数 connect_port 80 #利用80端口检查 } } real_server 192.168.0.224 80 { #RS节点 weight 1 TCP_CHECK { connect_timeout 8 nb_get_retry 3 delay_before_retry 3 connect_port 80 } } } 

以上keepalived配置文件在LVS主和备上都进行修改。
而后在lvs服务器上经过ipvsadm -C清除以前设置的规则
从新启动keepalived服务进行测试,操做过程以下:

[root@lvs01 ~]# /etc/init.d/keepalived stop #关闭主LVS的keepalived服务 Stopping keepalived: [ OK ] [root@lvs01 ~]# ipvsadm -Ln #没有ipvs规则 IP Virtual Server version 1.2.1 (size=4096) Prot LocalAddress:Port Scheduler Flags -> RemoteAddress:Port Forward Weight ActiveConn InActConn [root@lvs01 ~]# ip a | grep 240 #没有VIP [root@lvs01 ~]# /etc/init.d/keepalived start #启动keepalived服务 Starting keepalived: [ OK ] [root@lvs01 ~]# ipvsadm -Ln #出现ipvs规则 IP Virtual Server version 1.2.1 (size=4096) Prot LocalAddress:Port Scheduler Flags -> RemoteAddress:Port Forward Weight ActiveConn InActConn TCP 192.168.0.240:80 rr -> 192.168.0.223:80 Route 1 0 0 -> 192.168.0.224:80 Route 1 0 0 [root@lvs01 ~]# ip a | grep 240 #出现VIP inet 192.168.0.240/24 scope global secondary eth0:240 
相关文章
相关标签/搜索