LVS负载均衡模型及算法概述
集群类型
- LB: Load Balancing,负载均衡
- HA:High Availability, 高可用
- HP:High Performance, 高性能
负载均衡
负载均衡设备
Hardware:
F5,BIG IP
Citrix,Netscaler
A10 最便宜
Software:
四层 性能高,支持的特性少
LVS 中国
七层:反向代理,性能略次于四层,支持高级特性
nginx 俄罗斯
http、smtp、pop3、imap
haproxy
主要应用场景http、其他tcp(mysql,smtp)
LVS
Linux Virtual Server
组成部分:
ipvsadm:管理集群服务的命令行工具,工作在用户空间
ipvs:工作在内核,监控在input
LVS工作在INPUT链,所以iptables和LVS不能同时使用
模型前端叫调度器director,后端叫real_server
CIP:client IP
VIP:vrtual IP
DIP:director IP
RIP:real server IP
类型
LVS-NAT 地址转换
LVS-DR 直接路由(使用最多)
LVS-TUN 隧道
LVS-NAT遵循法则:
工作模式:
- 集群节点跟director必须在同一个IP网络中;
- RIP通常是私有地址,仅用于各集群节点间的通信;
- director位于client和real server之间,并负责处理进出的所有通信;
- realserver必须将网关指向DIP;
- 支持端口映射;
- realserver可以使用任意OS;
- 较大规模场景中,director易成为系统瓶颈;
LVS-DR遵循法则:
工作模式:
- 集群节点跟director必须在同一个物理网络中;
- RIP可以使用公网地址;
- director仅负责处理入站请求,响应报文由realserver直接发往客户端;
- realserver不能将网关指向DIP;
- 不支持端口映射;
- 支持大多数的OS(要求VIP可以隐藏)
LVS-TUN遵循法则:
工作模式:
- 通过一个IP报文封装另外一个报文
- 集群节点可以跨越互联网;
- RIP必须是可路由地址;
- director仅负责处理入站请求,响应报文由realserver直接发往客户端;
- realserver不能将网关指向DIP;
- 只有支持隧道功能的OS才能用于realserver;
- 不支持端口映射;
LVS10种调度方法:
固定调度:静态算法,不考虑连接数
rr:轮调,轮询
wrr:Weight,加权
sh:source hash,源地址hash绑定,比如session绑定
dh:destination hash,目的地址绑定,把同一类请求发往同一个服务器,比如后端有多台缓存服务器,把同一类请求发往已缓存服务器。
动态调度:动态算法,考虑连接数
lc:least connection 最少连接
active*256+inactive,谁小挑谁
wlc:加权最少连接,LVS默认算法
(active*256+inactive)/weight,谁小挑谁
sed:最短期望延迟,对wlc的改进
(active+1)*256/weight
nq:never queue,对sed的改进
LBLC:基于本地的最少连接,主要实现目标和dh一样,实际上并不考虑连接数,最常使用于缓冲服务器当中。
LBLCR:基于本地的带复制功能的连接
查看内核是否支持IPVS:
- cat /boot/config-2.6.32-358.el6.x86_64 | grep -i "vs"
- CONFIG_IP_VS=m
- CONFIG_IP_VS_IPV6=y
- # CONFIG_IP_VS_DEBUG is not set
- CONFIG_IP_VS_TAB_BITS=12
- # IPVS transport protocol load balancing support
- CONFIG_IP_VS_PROTO_TCP=y
- CONFIG_IP_VS_PROTO_UDP=y
- CONFIG_IP_VS_PROTO_AH_ESP=y
- CONFIG_IP_VS_PROTO_ESP=y
- CONFIG_IP_VS_PROTO_AH=y
- CONFIG_IP_VS_PROTO_SCTP=y
- # IPVS scheduler
- CONFIG_IP_VS_RR=m
- CONFIG_IP_VS_WRR=m
- CONFIG_IP_VS_LC=m
- CONFIG_IP_VS_WLC=m
- CONFIG_IP_VS_LBLC=m
- CONFIG_IP_VS_LBLCR=m
- CONFIG_IP_VS_DH=m
- CONFIG_IP_VS_SH=m
- CONFIG_IP_VS_SED=m
- CONFIG_IP_VS_NQ=m
- # IPVS application helper
- CONFIG_IP_VS_FTP=m
- CONFIG_OPENVSWITCH=m
- CONFIG_MTD_BLKDEVS=m
- CONFIG_SCSI_MVSAS=m
- 安装yum install ipvsadm
- ipvsadm用法:
- 管理集群服务
- 添加:-A -t|u|f service-address [-s scheduler]
- -t: TCP协议的集群
- -u: UDP协议的集群
- service-address: IP:PORT
- -f: FWM(firewallMark): 防火墙标记
- service-address: Mark Number
- 修改:-E
- 删除:-D -t|u|f service-address
- # ipvsadm -A -t 172.16.100.1:80 -s rr
- 管理集群服务中的RS
- 添加:-a -t|u|f service-address -r server-address [-g|i|m] [-w weight]
- -t|u|f service-address:事先定义好的某集群服务
- -r server-address: 某RS的地址,在NAT模型中,可使用IP:PORT实现端口映射;
- [-g|i|m]: LVS类型
- -g: DR getway
- -i: TUN Internet
- -m: NAT 地址伪装Masquerading
- [-w weight]: 定义服务器权重
- 修改:-e
- 删除:-d -t|u|f service-address -r server-address
- # ipvsadm -a -t 172.16.100.1:80 -r 192.168.10.8 -m
- # ipvsadm -a -t 172.16.100.1:80 -r 192.168.10.9 -m
- 查看
- -L|l
- -n: 数字格式显示主机地址和端口
- --stats:统计数据
- --rate: 速率
- --timeout: 显示tcp、tcpfin和udp的会话超时时长
- -c: 显示当前的ipvs连接状况
- --daemon:显示进程
- --sort:排序,默认升序
- 删除所有集群服务
- -C:清空ipvs规则
- 保存规则
- -S
- # ipvsadm -S > /path/to/somefile
- 载入此前的规则:
- -R
- # ipvsadm -R < /path/form/somefile
LVS负载均衡模型及算法概述的更多相关文章
- LVS负载均衡理论以及算法概要
一. LVS简介 LVS是Linux Virtual Server的简称,也就是Linux虚拟服务器, 由章文嵩博士发起的自由软件项目,它的官方站点是www.linuxvirtualserver.or ...
- (转)详解LVS负载均衡之三种工作模型原理和10种调度算法
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://linuxnx.blog.51cto.com/6676498/1195379 LV ...
- LVS负载均衡IP隧道模式原理介绍以及配置实战
LVS 基本工作原理 当用户向负载均衡调度器(Director Server)发起请求,调度器将请求发往至内核空间 PREROUTING 链首先会接收到用户请求,判断目标 IP 确定是本机 IP,将数 ...
- LVS负载均衡的三种模式和八种算法总结
三种LVS负载均衡模式 调度器的实现技术中,IP负载均衡技术是效率最高的,IP虚拟服务器软件(IPVS)是在linux内核中实现的。 LVS负载均衡模式---1.NAT模式 NAT用法本来是因为网络I ...
- lvs负载均衡的搭建
lvs负载均衡的搭建 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 在部署环境前,我们需要了解一下一些协议 一.什么是arp 地址解析协议,即ARP(Addr ...
- 实现基于LVS负载均衡集群的电商网站架构
背景 上一期我们搭建了小米网站,随着业务的发展,网站的访问量越来越大,网站访问量已经从原来的1000QPS,变为3000QPS,网站已经不堪重负,响应缓慢,面对此场景,单纯靠单台LNMP的架构已经无法 ...
- LVS负载均衡原理
一.LVS基本原理概述 LB集群的实现,LB即负载均衡集群 硬件:F5 BIG-IP,Citrix NetScaler,A10,Array,Redware 软件:Lvs,nginx,haproxy,a ...
- 项目详解2—LVS负载均衡详解
一.负载均衡集群介绍 1.集群 ① 集群(cluster)技术是一种较新的技术,通过集群技术,可以在付出较低成本的情况下获得在性能.可靠性.灵活性方面的相对较高的收益,其任务调度则是集群系统中的核心技 ...
- Linux中keepalived+LVS负载均衡的搭建测试
1.1 LVS简介 LVS(Linux Virtual Server),也就是Linux虚拟服务器, 是一个自由软件项目.使用LVS技术要达到的目标是:通过LVS提供的负载均衡技术和Lin ...
随机推荐
- SoapUI利用Groovy对response与断言的处理
1.对response的处理:(其中Test Request是request的名称) def groovyUtils = new com.eviware.soapui.support.GroovyUt ...
- centos7 安装遇到的问题
win7系统下安装centos7 1:首先是在U盘启动时候遇到的,Warning: /dev/root does not exist.没找到U盘的位置.这个问题两种方法,一种是去找到对应的设备名字 然 ...
- 树莓派进阶之路 (025) - ubuntu下使用VNC连接树莓派raspberry(转)
转载:http://www.embbnux.com/2014/03/24/on_ubuntu_use_vnc_connect_raspberry/ 参考: http://elinux.org/R ...
- Linux中tomcat启动很慢,SessionIdGeneratorBase.createSecureRandom耗时5分钟
通常情况下,tomcat启动只要2~3秒钟,突然有一天,tomcat启动非常慢,要花5~6分钟,查了很久,终于在这篇文章找到了解决方案,博主牛人啊. 原文参见:http://blog.csdn.NET ...
- 【java】switch case支持的6种数据类型
switch表达式后面的数据类型只能是byte,short,char,int四种整形类型,枚举类型和java.lang.String类型(从java 7才允许),不能是boolean类型. 在网上看到 ...
- 关于tensorboard启动问题
我在学习过程中遇到了tensorboard无法启动的问题. 按照网上的教程,我无法正常启动tensorboard,全过程没有报错,但是打开tensorboard显示 No dashboards are ...
- symbolicatecrash App Bug 分析工具
1.symbolicatecrash 简介 symbolicatecrash 是一个 Xcode 自带解析 iOS Crash 文件的工具. 其它下载地址 symbolicatecrash,密码:6p ...
- rhel 7 设置默认运行级别为图形
查看默认级别 # systemctl get-default multi-user.target # cat /etc/inittab # inittab is no longer used when ...
- 关于ViewPager设置属性页setCurrentItem会阻塞主线程ANR总结
关于android开发设置View Pager的直接跳转页set CurrentItem会阻塞主线程ANR. 根据网上解决的说法,分析源码: if (mFirstLayout) { // We don ...
- 【转】IT业给世界带来的危机
IT业给世界带来的危机 昨天写了文章之后,回忆起这几年在湾区的经历,觉得自己是一个很不幸的人.然而就在今天,我的自怜奇妙的转换成了另一种感情,因为我看到了更不幸的人…… 正在女朋友 Cinny 的父母 ...