LVS原理概述:
lvs是一个开源软件,是Linux virtual server的简写,即linux虚拟服务器,是一个虚拟的服务器集群系统,lvs集群采用ip负载均衡技术和基于内容的请求分发技术。将客户端的请求均衡的转移到后边的不同的服务器上,且调度器自动屏蔽掉服务器的故障,整个服务器集群结构对于用户是透明的。集群采用三层结构:负载均衡调度层、应用服务集群层、共享存储层。lvs调度层一般是两台主备lvs服务器,主要作用是平衡真实服务器中的负载和检查每个真实服务器中服务的完整性。
负载均衡集群常用软件有:lvs、haproxy、nginx
高可用集群常用软件:heartbeat、keepalived、corosync+pacemaker(RHCS)
功能:
ipvsadm负责数据分发(负载均衡)
keepalived负责lvs服务器错误检测和健康检查
lvs负载均衡技术:
1、VS/NAT(网络地址转换)
2、VS/DR(直接路由方法)
3、VS/TUN(IP隧道方法)
常用VS/DR和VS/TUN
lvs体系结构:
使用lvs架设的服务器集群系统有三个部分:最前端的负载均衡层-Load Balancer;中间服务器群组层-server Array;最底层数据共享层-shared storage表示。
Load Balancer层:位于集群系统的最前端,有一台或多台父子均衡调度器(Director server)组成,lvs模块就安装在Director server上,而Director主要作用类似于一个路由器,它含有完成lvs功能所设定的路由表,通过这些路由表把用户的请求发送到Real server上,同时在Director server上还要安装对Real server服务的监控模块Ldirectord(集成在heartbeat中),此模块用于检测各个Real server服务的健康状况。
Server Array层:由一组运行应用服务的机器组成,可以是web服务、mail服务、ftp服务、dns服务等。实际应用中Director server也可以同时兼任Real server的角色。
Shared Storage层:为所有Real server提供共享存储空间和内容一致的存储区域,一般可以使用NFS/CIFS网络文件共享数据,但是NFS在繁忙业务系统中性能不是很好,这是可以使用集群文件系统,如红帽的GFS2文件系统,oracle提供的ocfs2文件系统。可以使用iscsi、DM多路径存储、MFS分布式文件存储、DRBD
从整个lvs结构可以看出Director server是整个lvs的核心,linux系统(内核2.6)可以不用任何设置就支持lvs功能。
LVS安装和配置
第一种:通过ipvsadm命令行配置
第二种:通过红帽工具piranha来配置
通过ipvsadm命令行来配置:
1、yun install ipvsadm
2、加载ipvs规则,保存规则
3、在Director server上绑定vip
ifconfig eth0:0 192.168.0.200 netmask 255.255.255.0 up
4、Real server设置,/etc/sysctl.conf内核设置
5、Real server添加接口和路由规则
ifconfig lo:0 192.168.0.200 netmask 255.255.255.255 up
route add -host 192.168.0.200 dev lo:0
6、测试访问vip ip反复刷新网页出现不同网页则表示成功
一、通过红帽Piranha实现web负载均衡
声明:可以不用经过以上配置,直接通过web界面配置lvs比较简单
两台负载均衡调度服务器(主/备)、vip、两台Real server
piranha方案是基于lvs基础上设计的一套负载均衡解决方案。
一个活动lvs负载均衡调度器和一个备份的
yum install piranha -y
配置文件/etc/sysconfig/ha/lvs.cf
设定密码,启动服务,进入web界面配置,ip:3636
配置主lvs和备份lvs,配置添加lvs(vip信息),配置realserver信息,启动lvs服务pluse。
备份lvs和主lvs一样,直接拷贝lvs.cf到相应目录
测试:
ipvsadm -ln //查看lvs链接状态
二、通过heartbeat搭建lvs高可用集群
一台主心跳服务器和一台备份心跳服务器
两台Real sever
yum install heartbeat heartbeat-libs heartbeat-devel ldirectord
修改/etc/ha.d/ha.cf文件
加载内核加载watchdog
#modprobe softdog
在/etc/modprobe.d下添加watchdog.conf
options softdog nowayout=0
资源文件/etc/ha.d/haresources修改
认证文件/etc/ha.d/authkeys权限600
配置/etc/ha.d/ldirectord.cf
主心跳服务器配置完后,拷贝/etc/ha.d目录下的authkeys、haresources、ha.f、ldirectord.cf到备份心跳服务器。
启动服务后,正常的话会多一个eth0:0接口
在Real server上添加接口和路由
#ifconfig eth0:0 192.168.0.200 netmask 255.255.255.255 up
#route add -host 192.168.0.200 dev eth0:0
然后测试ipvsadm -Lnc查看详细链接情况
三、通过keepalived搭建lvs高可用集群
两台负载均衡调度服务器(主/备)、VIP、两台Real server
源码编译安装keepalived ./configure --prefix=/usr/local/keepalived
创建软连接,修改主备配置文件,Real server上添加接口和路由规则
- 负载均衡、LVS概述
1. 负载均衡概述 负载均衡的基本思路是:在一个服务器集群中尽可能的平衡负载量.通常的做法是在服务器前端设置一个负载均衡器(一般是专门的硬件设备).然后负载均衡器将请求的连接路由到最空闲的可用服务器. ...
- 1. LVS概述
1.LVS介绍 LVS是linux virtual server的简写linux虚拟服务器,是一个虚拟的服务器集群系统,可以再unix/linux平台下实现负载均衡集群功能 2.LVS组成 LVS由2 ...
- LVS负载均衡集群服务搭建详解(一)
LVS概述 1.LVS:Linux Virtual Server 四层交换(路由):根据请求报文的目标IP和目标PORT将其转发至后端主机集群中的某台服务器(根据调度算法): 不能够实现应用层的负载均 ...
- LVS之NAT模型、DR模型配置和持久连接
前言:继LVS概述,本篇实现NAT模型和DR模型下的负载均衡. NAT模型: LVS-NAT基于cisco的LocalDirector.VS/NAT不需要在RealServer上做任何设置,其只要能提 ...
- LVS.md
LVS 概述 简介 LVS是Linux Virtual Server的简称,也就是Linux虚拟服务器, 是一个由章文嵩博士发起的自由软件项目,官方站点.现在LVS已经是 Linux标准内核的一部分, ...
- LVS介绍及相关配置
一. LVS概述 LVS是一种工作在四层协议上的负载均衡解决方案,在1998年5月由章文嵩博士创建.目前广泛使用的负载均衡模型主要有: 1)工作在四层协议(LVS):主要用于四层协议上的负载均衡,性能 ...
- LVS实现四层负载均衡
LVS详解(思维导图) 1. 集群概述 1.1 Linux Cluster Linux Cluster的类型 LB(Load Balance) HA(High Available) HP(High P ...
- 一次 Keepalived 高可用的事故,让我重学了一遍它!
原文首发: 你好,我是悟空. 前言 上次我们遇到了一个 MySQL 故障的事故,这次我又遇到了另外一个奇葩的问题: Keepalived 高可用组件的虚拟 IP 持续漂移,导致 MySQL 主从不断切 ...
- LVS集群之原理及概述(1)
一. 概述 什么是集群,集群的特点.功能和分类.Linux环境下用哪些开源软件来构建一个功能强而有稳定的集群系统.了解国人内核级负载均衡开源项目linux虚拟服务器,简称LVS. 1.1 定义 集群是 ...
随机推荐
- C++学习笔记(八):函数重载、函数指针和函数对象
函数重载 函数重载是指在同一作用域内,可以有一组具有相同函数名,不同参数列表的函数,这组函数被称为重载函数.重载函数通常用来命名一组功能相似的函数,这样做减少了函数名的数量,避免了名字空间的污染,对于 ...
- Oracle- PL/SQL DEV工具的使用收集
1.工具---首选项---用户界面---编辑器----定制关键词 里面可以选择关键字是否大写 2.美化代码段,点击菜单edit,然后pl/sql beautifer,快捷键:PL/SQL Develo ...
- HBase in 2013
2013年马上就要过去了,总结下这一年HBase在这么一年中发生的主要变化.影响最大的事件就是HBase 0.96的发布,代码结构已经按照模块化release了,而且提供了许多大家迫切需求的特点.这些 ...
- Android 调用系统的分享[完美实现同一时候分享图片和文字]
android 系统的分享功能 private void share(String content, Uri uri){ Intent shareIntent = new Intent(Intent. ...
- Android Studio导入项目
原文:http://ask.android-studio.org/?/article/21 本篇教程中使用到的Android Studio版本为1.0, Eclipse ADT版本23.0.4.请尝试 ...
- 基于Android 平台简易即时通讯的研究与设计[转]
摘要:论文简单介绍Android 平台的特性,主要阐述了基于Android 平台简易即时通讯(IM)的作用和功能以及实现方法.(复杂的通讯如引入视频音频等可以考虑AnyChat SDK~)关键词:An ...
- SICP 习题 (1.14)解题总结
SICP 习题 1.14要求计算出过程count-change的增长阶.count-change是书中1.2.2节讲解的用于计算零钱找换方案的过程. 要解答习题1.14,首先你需要理解count-ch ...
- maven 把spring项目打包成可执行的文件
转载自http://www.mamicod.e.com/info-detail-635726.html 最近需要解决Maven项目导入可执行的jar包的问题,如果项目不包含Spring,那么使用mvn ...
- Android ListView快速定位(四)
方法四: 添加一个EditText,作为搜索框 + Filter 其实这个不算第四个方法,因为与第二个一样,主要是实现Filter. 但是对于EditText的监听,我以前也没有写过,所以也记录一下. ...
- Linux内核学习笔记2
http://www.cnblogs.com/bastard/category/412387.html