LVS-负载均衡集群部署
简介:LVS是一种集群技术,采用IP负载均衡技术和基于内容请求分发技术,调度器具有很好的吞吐量,将请求均衡的转移到不同服务器上执行,且调度器自动屏蔽掉服务器的故障,从而将一组服务器构成一个高性能,高可用的虚拟服务器,整个服务器集群的结构对客户是透明的,而且无需修改客户端和服务端的程序,
为此,在设计师需要考虑系统的透明性,可伸缩性,高可用性和管理性,一般来说,LVS集群采用三层 结构,体系结构如下所示:

LVS主要组成部分:
*负载调度器(Load balancer /Directory).它是整个集群对外面的前端机,负责将客户请求发送到一组服务器上执行,而客户认为服务是来自一个IP地址(也就是虚拟IP地址)上的
*服务器池(server pool/Realserver)是一组真正执行客户请求的服务器,执行的服务一般有WEB,MAIL,FTP和DNS等
*共享存储(shared storage)它为服务器池提供了一个共享的存储区,这样很容易使得服务器池有相同的内容,提供相同的服务,
LVS负载均衡 方式:
(1)LVS/NAT:一种最简单的方式,所有的RealServer只需要将自己的网关指向Directory即可,客户端可以是任意操作系统,但此方式下,一个Directory即可.客户端可以是任意的操作系统,但此方式下,Directory也可以兼为一台RealServer比较有限,在LVS/NAT的方式下,Directory也可以兼为一台RealServer.LVS/NAT的体系结构如图所示:

(2)IP隧道(IPTUNnel):简称TUN模式,采用开放式的网络结构,负载调度器仅作为客户机的访问入口,各节点通过各自的internet连接直接回应客户机,而不再经过负载均衡调度器,服务器节点分散在互联网中不要位置,具有独立的公网IP地址,通过专用IP隧道与负载均衡调度器相互通信.
(3)直接路由(Direct Routing)简称DR模式,采用半开放式的网络结构,与TUN模式的结构类似,但各节点并不是分散在各地,而是与调度器位于同一个物理网络,负载均衡调度器与各节点服务器通过本地网络连接,不需要建立专用的IP隧道,
以上三种,NAT方式只需要一个公网IP地址,从而成为最易用的一种负载均衡模式,安全性也比较好,许多硬件负载设备就是采用这种方式,相比较而言,DR模式和TUN模式的负载能力更加强大,使用范围更广,但节点的安全性要稍差一些,
负载均衡 调度算法:
*轮询:将收到的访问请求按照顺序轮询轮流分配给集群中的个节点(真实服务器),均等地对待每一台服务器,而不管服务器实际的连接数和系统负载
*加权轮询:根据真实服务器的处理能力轮流分配收到的访问请求,调度器可以自动查询各节点负载情况,并动态调整其权重,这样可以保证处理能力强的服务器承担更多的访问流量,
*最少连接:根据真实服务器已建立的连接数进行分配,将收到的访问请求优先分配给连接数量最少的节点,如果所有的服务器节点性能相近,采用这种方式可以更好的均衡负载
*加权轮询:在服务器节点的性能差异较大的情况下,可以为真实服务器自动调取权重,权重较高的节点将承担更大的比列的活动连接负载
------------------------------------------------------------------------------------------------------------------------------------
LVS-NAT模式
实验环境:
Server:LVS-分配器:
外网IP------Eth0:192.168.1.1
内网IP------Eth1:192.168.2.128
Web-server1
内网IP:192.168.2.51
Web-server2
内网IP:192.168.2.52
在LVS上开启路由转发功能
[root@localhost ~]# vim /etc/sysctl.conf #开启自动生效

root@localhost ~]# sysctl –p #让配置立即生效
配置LVS NAT模式集群并安装LVS管理工具:ipvsadm
[root@localhost ~]# yum localinstall -y /media/cdrom/Packages/ipvsadm-1.26-2.el6.x86_64.rpm [A1]
添加一个虚拟服务:VIP地址 :192.168.1.1,服务端口:80
[root@localhost ~]# ipvsadm -A -t 192.168.1.1:80 -s rr[A2]
[A1]因配置文帝yum源,可采用这种方式安装ipvsadm软件
[A2]-A:添加一个虚拟服务
-t:表示TCP的服务 VIP:PORT
-s:制定调度算法 rr表示route-robin
添加虚拟服务后端的real server地址:
[root@localhost ~]# ipvsadm -a -t 192.168.1.1:80 -r 192.168.2.51 -m
[root@localhost ~]# ipvsadm -a -t 192.168.1.1:80 -r 192.168.2.52 -m
查看:
[root@localhost ~]# ipvsadm -L –n
[A1]-a:表示添加real server
-r:制定real server的ip地址
-m:表示masquerade也就是NAT方式LVS

保存:
[root@localhost ~]# /etc/init.d/ipvsadm save
ipvsadm: Saving IPVS table to /etc/sysconfig/ipvsadm: [确定]
总结:
1:配置网络环境,添加网卡eth1
2:开启路由转发功能
3:安装配置LVS NAT
ipvsadm -A -t 192.168.1.1:80 -s rr
ipvsadm -a -t 192.168.1.1:80 -r 192.168.2.51 -m
ipvsadm -a -t 192.168.1.1:80 -r 192.168.2.52 –m
后端web-server1:192.168.2.51
web-server2:192.168.2.52上面配置
配置web-server 192.168.2.51的ip和网关
Web-2.51: eth0: vmnet1 :192.168.2.51 网关:192.168.2.128
Web-2.52: eth0: vmnet1 :192.168.2.52 网关:192.168.2.128
[root@localhost ~]# vim /etc/sysconfig/networkscripts/ifcfg-eth0


[root@localhost ~]# /etc/init.d/network restart
测试两台web服务能否ping通?

接下两台服务器都安装httpd并启动
[root@localhost ~]# yum install -y httpd
[root@localhost ~]# /etc/init.d/httpd start
创建一个默认测试网页
[root@localhost ~]# echo "server 192.168.2.51" >>/var/www/html/index.html
[root@localhost ~]# vim /etc/httpd/conf/httpd.conf

[root@localhost ~]# /etc/init.d/httpd restart
在web 2.52上安装httpd(配置与上述一样)
[root@localhost ~]# yum install -y httpd
[root@localhost ~]# /etc/init.d/httpd start
创建一个默认测试网页
[root@localhost ~]# echo "server 192.168.2.52" >>/var/www/html/index.html
[root@localhost ~]# vim /etc/httpd/conf/httpd.conf

root@localhost ~]# /etc/init.d/httpd restart
测试LVS-NAT模式
通过elinks浏览器 realserver是否正常:
[root@localhost ~]# elinks 192.168.2.51 --dump
server 192.168.2.51
[root@localhost ~]# elinks 192.168.2.52 --dump
server 192.168.2.52
通过elinks浏览器访问VIP,测试分发器是否正常

查看LVS NAT集群请求状态
[root@localhost ~]# 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.1.1:80 rr
-> 192.168.2.51:80 Masq 1 0 2
-> 192.168.2.52:80 Masq 1 0 2
查看LVS分发情况
[root@localhost ~]# ipvsadm -L -n --stats

查看速率

LVS-负载均衡集群部署的更多相关文章
- 高性能Linux服务器 第11章 构建高可用的LVS负载均衡集群
高性能Linux服务器 第11章 构建高可用的LVS负载均衡集群 libnet软件包<-依赖-heartbeat(包含ldirectord插件(需要perl-MailTools的rpm包)) l ...
- 项目实战2—实现基于LVS负载均衡集群的电商网站架构
负载均衡集群企业级应用实战-LVS 实现基于LVS负载均衡集群的电商网站架构 背景:随着业务的发展,网站的访问量越来越大,网站访问量已经从原来的1000QPS,变为3000QPS,网站已经不堪重负,响 ...
- LVS之2---基于LVS负载均衡集群架构
LVS之2---基于LVS负载均衡集群架构实现 目录 LVS之2---基于LVS负载均衡集群架构实现 ipvsadm software package Options 常用命令 保存及重载规则 内存映 ...
- LVS负载均衡集群--DR模式部署
目录: 一.LVS-DR数据包流向分析 二.DR 模式的特点 三.LVS-DR中的ARP问题 四.DR模式 LVS负载均衡群集部署 一.LVS-DR数据包流向分析 1.为方便进行原理分析,将clien ...
- 实现基于LVS负载均衡集群的电商网站架构
背景 上一期我们搭建了小米网站,随着业务的发展,网站的访问量越来越大,网站访问量已经从原来的1000QPS,变为3000QPS,网站已经不堪重负,响应缓慢,面对此场景,单纯靠单台LNMP的架构已经无法 ...
- LVS负载均衡集群
回顾-Nginx反向代理型负载 负载均衡(load balance)集群,提供了一种廉价.有效.透明的方法,来扩展网络设备和服务器的负载.带宽.增加吞吐量.加强网络数据处理能力.提高网络的灵活性和可用 ...
- LVS负载均衡集群服务搭建详解(二)
lvs-nat模型构建 1.lvs-nat模型示意图 本次构建的lvs-nat模型的示意图如下,其中所有的服务器和测试客户端均使用VMware虚拟机模拟,所使用的CentOS 7 VS内核都支持ipv ...
- LVS负载均衡集群服务搭建详解(一)
LVS概述 1.LVS:Linux Virtual Server 四层交换(路由):根据请求报文的目标IP和目标PORT将其转发至后端主机集群中的某台服务器(根据调度算法): 不能够实现应用层的负载均 ...
- Nginx+Tomcat7+Mencached负载均衡集群部署笔记
Nginx+Tomcat+Memcached负载均衡集群服务搭建 操作系统:CentOS6.5 本文档主要解说,怎样在CentOS6.5下搭建Nginx+Tomcat+Memcached负载均衡集群s ...
- Linux 笔记 - 第十八章 Linux 集群之(二)LVS 负载均衡集群
一.前言 Linux 集群从功能上可以分为两大类:高可用集群和负载均衡集群.上一篇已经讲解了 HA 高可用集群,此节讲解负载均衡集群. 负载均衡集群(Load Balance Cluseter,简称 ...
随机推荐
- Xcode9新特性介绍-中文篇
背景: Xcode 9 新特性介绍: 1.官方原文介绍链接 2.Xcode9 be ta 2 官方下载链接 本文为官方介绍翻译而来,布局排版等都是按照官方布局来的. 与原文相比,排版上基本还是熟悉的配 ...
- Visual Studio 中指定自定义生成事件
自定义生成事件打开方式 通过指定自定义生成事件,可以在生成开始之前或在它完成之后自动运行命令.在Visual Studio中通过右键项目->属性 进入项目属性菜单. 自定义生成事件的语法 生成事 ...
- jQuery淡入淡出的轮播图
html结构: <div class="banna"> <ul class="img"> ...
- 异常:java.lang.NoSuchMethodError: org.apache.poi.ss.usermodel.Workbook.getCellStyleAt
背景 最近公司所有新项目要使用最新高效快速开发框架nature-framework,框架本身结合NatureMap已经集成excel的高效导入功能,我们要实现高性能的导出功能,因为最新的jxls-2. ...
- Windows PowerShell 默认颜色
屏幕背景:1,36,86 屏幕文字:238,237,240 弹出文字:0,128,128 弹出窗口背景:255,255,255
- 前端自动化测试python+webdriver
前言:很多做测试的朋友的就知道,python+webdriver 可以做自动化测试,这对前端开发是非常有用的. python 入门我就不讲了 ,推荐学习 廖雪峰老师的python入门3.5新版哈 ...
- encodeURI与decodeURI
Global对象的ecodeURI方法可以对URI进行编码,与其类似的还有一个方法encodeURIComponent方法. 相应的对URI的解码方法也有两个:decodeURI.decodeURIC ...
- 深度学习:Keras入门(一)之基础篇
1.关于Keras 1)简介 Keras是由纯python编写的基于theano/tensorflow的深度学习框架. Keras是一个高层神经网络API,支持快速实验,能够把你的idea迅速转换为结 ...
- SSIM(结构相似度算法)不同实现版本的差异
前言 最近用ssim测试图片画质损伤时,发现matlab自带ssim与之前一直使用的ssim计算得分有差异,故和同事开始确定差异所在. 不同的SSIM版本 这里提到不同的ssim版本主要基于matla ...
- Docker-compose 多个Docker容器管理:以MYSQL和Wordpress为例
搬砖的陈大师版权所有,转载请注明:http://www.lenggirl.com/tool/docker-compose.html Docker-compose 多个Docker容器管理:以MYSQL ...