lvs介绍
1Linux集群及系统扩展的方式概述
集群是有多台服务器组织在一起,一起工作,因为单台服务器的并发响应能力是有限的,响应处理能力也是有限的所有有了集群的出现
在系统扩展有2种方法:
1 向上扩展:是指换一台性能更高的服务器来取代现有服务器,但这样子因为单台的服务器运算性能是有限的,而且这样造价相当昂贵。
2向外扩展:是指多增加一台服务器来分担现服务器的工作。
2Linux集群类型及调度方法详解
集群的类型有:
1 lvs:负载均衡:将客户端的请求通过一定的调度算法分发给不同的后端服务器来处理
注意在lvs如果一个客户发送请求,被分发给后端某一个服务器上,当这个客户端再次发送请求时,可能会被发送的另一台后端的服务器上,这样一次的会话内容信息就会丢失,为了解决这一问题有一下几种方法:
1 做静态绑定,将同一台客户端的请求分发给同一台后端服务器上,但这样一来就破坏的负载均衡的意义
2 在后端服务器的后面做共享存储,如结构化数据可以存放在mysql等关系型数据库中,非结构化数据如图片存放在nfs当中,
3 在后端服务器之间做信息的共享
2 HA:高可用集群:它具有冗余性注重服务器的在线使用时间指高可用性 MTBF (平均无故障时间)/MTBF+MTTR(故障修复时间)
3 HP:高性能集群是把计算量分隔出去
负载均衡的调度算法:
1 通过硬件设备实现调度:如 big-ip A10 等硬件设备
2 通过软件层来实现调度:
常用的软件调度:
lvs:它是工作在传输层 内核空间的 所以他响应并发是不受到套接字的限制,但是他没有客户端工具,调度能力有限不能完成更高级的调度设置,所以通常用lvs做一级调度,用nginx来最二级调度。
我们知道iptables是指定规则的用户空间工具,在iptables有5个链;
一般数据的流向是2种:1 prerouting------input----到用户空间------output -------postrouting
2 prerouting ------forward ------------------------------------postrouting
但lvs 工作在input链上,它的工作数据流:prerouting -----------input--------------postrouting
ipvs框架是来判断是否是集群的,若是直接交给postrouting ,管理工具是ipvsadm
Nginx和haproxy是应用层的程序不过他们可以模拟工作在传输层
http fastcgi ats perlbal 工作在应用层
3 lvs常见的四种集群lvs-nat、lvs-dr、lvs-tun、lvs-fullnat优点及使用场景
lvs 常见的有四种类型:
1 lvs—nat:
1修改请求报文的目标ip将客户端的vip改为后端服务器的rip ,进行分发它请求响应都需要经过director, 由于请求和响应都经director,所以调度器容易成为集群瓶颈
2 rip与dip必须同一网段 rip的网关指向dip
3支持端口映射,可以修改请求报文的目标端口
4 vs必须是linux系统, rs可以是任意
2 lvs-dr :直接路由:通过封装的MAC地址进行响应,
1 Director与rs 都接在同一个交换机上 ,客户端:通过广播方式得到vs的MAC地址,封装原MAC 和目标MAC 传给director,Director:在将原MAC地址为dip所在接 口的MAC 目标mac给为rs的rip网口的 MAC地址 派发给rs 而客户端请求时的原ip和目标ip不变 、,Rs 接收到后应为rs上也配有vip所以将直接响应客户端,不再经过 director
但有个问题:
1此处:在客户端广播是,rs的vip地址不做响应
2在接入这个网络后vip不做通过,防止ip冲突
实现的办法有:
1 arptables / nftables 来写规则阻断
2 在linux内核中有两个参数来设置 arp_announce =2 arp_ignore =1
3 做与director做静态绑定,
1 rs的rip可以做私网地址也可以做公网地址,与dip在同一网络 rip网关不指向dip
2 rs与director在同一个物理网络
3请求报文经过director 响应不经过director
4 并不支持端口映射
3 lvs-tun:隧道: 在原ip报文外面在封装一个ip首部 不修改请求报文首部而是在原ip报文外再封装一个ip首部,将报文发送为rs
1 dip vip rip 都在公网地址
2rs的网关不指向dip
3请求报文经过director 响应报文不经过director
4不支持端口映射
5 rs的os系统必须支持隧道功能
4lvs-fullnat:非标准的 可以是跨机房在director上有个nat追加表,可以根据nat表的记录进行将ip的修改
请求响应都经过director
1 vip公网地址 ,rip 和dip 是私网地址且同常不在同一网络中
2 rs收到请求的源地址是dip 只需响应给director 再由director响应给客户端
3 请求和响应都经过director
4 支持端口映射
调度算法:根据调度时是否考虑各rs当前负载状态可以分为静态和动态
静态: 仅根据算法自身进行调度
1 RR: 轮询
2WRR: 加权轮询
3SH:实现session sticy 源ip地址hash表将来自同一ip地址请求始终发送给之前的同一个rs 实现会话绑定。
4 DH 目标地址哈希:将发往同一目标地址的请求始终转发到第一次的rs上
动态方法: 主要根据每个RS当前的负载状态和调度算法进行调度
1 LC: 最小连接 当overhead 值最小的 Overhead = activconns * 256 + inctiveconns
2 WLC: 加权最小连接 Overhead = (activconns * 256 + inctiveconns)/weight
3 SED:小的值挑出 权重大的挑中 Overhead=(activeconns + 1) * 256 /weight
4 NQ:从不排队
5 LBLC:动态的DH算法
6LBLR:带复制功能的LBLC
lvs介绍的更多相关文章
- LVS 介绍
LVS 介绍 说明: LVS是Linux Virtual Server的简称 LVS是一个实现负载均衡的开源软件项目 LVS效率要高于Nginx LVS工作在ISO的第4层(传输层) LVS架构有三层 ...
- 负载均衡集群介绍、LVS介绍、LVS调度算法、LVS NAT模式搭建
7月4日任务 18.6 负载均衡集群介绍18.7 LVS介绍18.8 LVS调度算法18.9/18.10 LVS NAT模式搭建 扩展lvs 三种模式详解 http://www.it165.net/a ...
- Linux centosVMware 负载均衡集群介绍、LVS介绍、LVS调度算法、LVS NAT模式搭建
一.负载均衡集群介绍 主流开源软件LVS.keepalived.haproxy.nginx等 其中LVS属于4层(网络OSI 7层模型),nginx属于7层,haproxy既可以认为是4层,也可以当做 ...
- LVS 介绍以及配置应用
1.负载均衡集群介绍 1.1.什么是负载均衡集群 负载均衡集群提供了一种廉价.有效.透明的方法,来扩展网络设备和服务器的负载.带宽.增加吞吐量.加强网络数据的处理能力.提高网络的灵活性和可用性 搭建负 ...
- 负载均衡集群相关、LVS介绍、LVS调度算法、LVS NAT模式搭建
1.负载均衡集群相关 2.LVS的三种模式:NAT.DR .IP tunnel 3. LVS的调度算法(共有8种) 4.LVS NAT模式搭建准备条件: 在分发服务器上安装:yum install ...
- 负载均衡集群介绍 LVS介绍 LVS调度算法 LVS NAT模式搭建
LVS BAT模式搭建 更改主机名: hostnamectl set-hostname centos7-three bash 准备工作 • 三台机器 • 分发器,也叫调度器(简写为dir) • 内网: ...
- linux系统构架 - LB集群之LVS介绍
LB 集群是 load balance 集群的简写,翻译成中文就是负载均衡集群.常用的负载均衡开源软件有 nginx.lvs.keepalived ,商业的硬件负载设备 F5.Netscale. LB ...
- 【摘自lvs官网】lvs介绍
Linux Virtual Server项目的目标 :使用集群技术和Linux操作系统实现一个高性能.高可用的服务器,它具有很好的可伸缩性(Scalability).可靠性(Reliability)和 ...
- LVS介绍及相关配置
一. LVS概述 LVS是一种工作在四层协议上的负载均衡解决方案,在1998年5月由章文嵩博士创建.目前广泛使用的负载均衡模型主要有: 1)工作在四层协议(LVS):主要用于四层协议上的负载均衡,性能 ...
随机推荐
- QT 开发小记
1.开发socket网络通信时,需要在.pro 文件中添加 network项 QT += network 2. 报错: mutilple definition of 时,查看 .pro ...
- PHP程序守护进程化
一般Server程序都是运行在系统后台,这与普通的交互式命令行程序有很大的区别.glibc里有一个函数daemon.调用此函数,就可使当前进程脱离终端变成一个守护进程,具体内容参见man daemon ...
- MS SQL Server 建库建表
CREATE DATABASE Test use Test --创建用户类型表CREATE TABLE UserType ( ID INT NOT NULL identity(1,1) primary ...
- ActiveMQ在Windows下的安装与启动(懒人专属)
其实这些ActiveMQ官网都有,但是如果你懒得看官网,那就直接看这吧! 1. 官网下载最新的ActiveMQ安装包 apache-activemq-x.x.x-bin.zip并解压 2.进入安装 ...
- Windows下Oracle 11g安装以及创建数据库
安装数据库 事实上Oracle安装 1.安装准备 Oracle的安装包下载以后是两个压缩包,同时选中两个压缩包右击进行解压 2.解压完成如下图所示 3.双击 setup.exe 文件进行安装,会弹出以 ...
- JavaWEB后端支付银联,支付宝,微信对接
注:本文来源于:< JavaWEB后端支付银联,支付宝,微信对接 > JavaWEB后端支付银联,支付宝,微信对接 标签(空格分隔): java 项目概述 最近项目需要后端打通支付,所 ...
- Confluence 6 配置验证码(Captcha)来防止垃圾
如果你的 Confluence 站点是对公众开放的(允许匿名用户使用,添加评论,创建页面等),你可能会发现你的站点会被自动创建很多垃圾页面,评论或者其他垃圾内容. 你可以配置让 Confluence ...
- Confluence 6 代理和 HTTPS 详细配置指南链接
详细配置指南 更多有关连接器示例,我们提供了一些按步骤配置的指南来帮助你启用 HTTPS 并正确配置你的代理. HTTPS: Running Confluence Over SSL or HTTPS ...
- Confluence 6 MySQL 输入你的数据库细节
Confluence 的安装向导将会指导你一步一步的在 Confluence 中配置安装 MySQL 数据库. 使用 JDBC 连接(默认) JDBC 是推荐的连接你的 Confluence 到数据库 ...
- Confluence 6 Microsoft SQL Server 设置准备
在开始前,请检查: 请查看 Supported Platforms 页面来获得 Confluence 系统支持的 SQL Server 数据库版本.你需要在安装 Confluence 之前升级你的 O ...