LVS的介绍
LVS是什么?
LVS(Linux Virtual Server,Linux虚拟服务器)是由章文嵩开发的一款开源软件(遵循GPL协议)。LVS工作在layer 4,又称为四层路由/四层交换,能够根据请求报文的目标IP地址和目标PORT将其调度转发至后端的某台服务器上,调度转发是根据调度算法来进行的。
LVS由两部分组成,分别是工作在内核空间的ipvs框架和工作在用户空间的ipvsadm命令。ipvsadm是工作在用户空间的命令行工具,用于管理集群服务及集群服务上的Real Server(RS),而ipvs则是工作于内核上的netfilter的INPUT钩子上的程序,其功能是根据用户定义的集群实现对请求报文的转发。
LVS支持基于TCP、UDP、SCTP、AH、EST、AH_EST等协议进行调度。
为什么要使用LVS?
LVS是负载均衡能力最强的一款软件,对于选择LVS作为负载均衡的原因总结如下。
1、相比于Nginx、Haproxy等负载均衡器,LVS支持较大的并发量。Nginx、Haproxy是工作在七层的负载均衡器,因此需要监听在一个端口上,同时对于每一个客户端都需要打开一个套接字文件来接受请求数据,当在应用层分析完数据时,有需要扮演成客户端角色向后端的服务器主机发送请求报文,不仅需要打开大量套接字文件,还需要有多个随机端口可以使用,而端口数最多只有65535个,并且其中有一部分端口是不能使用的。因此,工作在七层的负载均衡软件(如Nginx、Haproxy等)的最大并发数受限于能够打开的套接字文件数(内核需要打开很多的文件描述符来维护)以及能使用的随机端口数。对于LVS而言,因此它工作在四层,所以不需要监听在某个端口以响应客户端请求,因此不需要打开套接字接受和发送数据,同时也不需要使用端口,所有功能均在ipvs中实现,因此LVS的性能更高,支持的并发量更大。据统计,LVS的最大并发量可以达到400~500w。
2、LVS是一款开源且免费的软件,结合Linux使用可以大大降低企业的应用成本。
3、LVS具有可伸缩性。当一台服务器负载压力增长时,系统可以在不降低服务质量的情况下通过扩展来满足需求。
4、LVS具有高可靠性。这在国内很多大型的、关键性的Web站点实践中得到印证。
LVS的三种搭建模型
NAT模式
优点:集群中的物理服务器可以使用任何支持TCP/IP操作系统,物理服务器可以分配Internet的保留私有地址,只有负载均衡器需要一个合法的IP地址。不足:扩展性有限。当服务器节点(普通PC服务器)数据增长到20个或更多时,负载均衡器将成为整个系统的瓶颈,因为所有的请求包和应答包都需要经过负载均衡器再生。假使TCP包的平均长度是536字节的话,平均包再生延迟时间大约为60us(在Pentium处理器上计算的,采用更快的处理器将使得这个延迟时间变短),负载均衡器的最大容许能力为8.93M/s,假定每台物理服务器的平台容许能力为400K/s来计算,负责均衡器能为22台物理服务器计算。
TUN模式
我们发现,许多Internet服务(例如WEB服务器)的请求包很短小,而应答包通常很大。
优点:负载均衡器只负责将请求包分发给物理服务器,而物理服务器将应答包直接发给用户。所以,负载均衡器能处理很巨大的请求量,这种方式,一台负载均衡能为超过100台的物理服务器服务,负载均衡器不再是系统的瓶颈。使用VS-TUN方式,如果你的负载均衡器拥有100M的全双工网卡的话,就能使得整个Virtual Server能达到1G的吞吐量。
不足:但是,这种方式需要所有的服务器支持”IP Tunneling”(IP Encapsulation)协议,我仅在Linux系统上实现了这个,如果你能让其它操作系统支持,还在探索之中。DR模式
优点:和VS-TUN一样,负载均衡器也只是分发请求,应答包通过单独的路由方法返回给客户端。与VS-TUN相比,VS-DR这种实现方式不需要隧道结构,因此可以使用大多数操作系统做为物理服务器,其中包括:Linux 2.0.36、2.2.9、2.2.10、2.2.12;Solaris 2.5.1、2.6、2.7;FreeBSD 3.1、3.2、3.3;NT4.0无需打补丁;IRIX 6.5;HPUX11等。
不足:要求负载均衡器的网卡必须与物理网卡在一个物理段上
使用LVS搭建基于四层网络模型的负载均衡器 DR模式
命令解释
1 | rr:轮循 |
1 | kernel parameter: |
1 | yum install ipvsadm -y |
1 | 添加:ipvsadm -a -t|u|f service-address -r server-address [-g|i|m] [-w weight] |
- 拓扑图
- 开始搭建
1.在192.168.150.11 中添加192.168.150.100的网卡
1 | 添加网卡 ifconfig eth0:2 192.168.150.100/24 |
删除 eth0:2网卡 ifconfig eth0:2 down
2.调192.168.150.12 和 192.168.150.13的内核协议
1 | echo 1 > /proc/sys/net/ipv4/conf/eth0/arp_ignore |
3.配置192.168.150.12 和 192.168.150.13环行路由
1 | ifconfig lo:2 192.168.150.100 netmask 255.255.255.255 |
4.在 192.168.150.12 和 192.168.150.13中安装 httpd
1 | yum install httpd -y |
5在浏览器中输入192.168.150.12:80测试
6.在192.168.150.11 中安装 ipvsadm
1 | yum install ipvsadm -y |
7.验证:
1 | 浏览器访问 192.168.150.100 看到负载 F5属性 |