lvs初探

1,lvs是什么

lvs是Linux Virtual Server缩写,linux虚拟服务器,担任负载调度器(load balance)的角色,它不提供任何服务,用户请求到这里的时候,它是将客户需求转发至后端真正提供服务的服务,LVS分为两部分组成,ipvsadm管理集群服务的命令行工具,ipvs,是内核模块。由于ipvs采用基于ip负载均衡技术,所以具有很好的吞吐量。

lvs简单拓扑

blob.png

lvs相关术语

RS:后端服务器

CIP: 客户端IP

VIP:虚拟IP

RIP:后端服务器IP

DIR:调度器Director IP

2,lvs集群类型。

1,lvs-nat: 网络地址转换

接到用户请求,通过网络地址地址转换,(类似iptables的DNAT),根据预设的调度算法,调度器重写请求报文的目标地址,将请求报文分发到后端的相应的真实服务器;真实服务器的响应报文通过调度器时,响应报文的源地址被重写,返回客户端。完成整个请求。 NAT模式是通过修改请求报文的目标ip跟port完成的转发,修改响应报文的源地址的ip,port完成对客户端的透明性,所有nat模式有以下特性

(1) 请求报文响应报文都通过Director,Director容易成为性能上的瓶颈

(2)RIP,DIP在同一个私网网段

(3)VS是linux系统,RS可以是任意OS

2,lvs-dr:直接路由技术

DR模式是通过改写请求报文的MAC地址完成,将请求报文发送到后端的RS,RS将响应报文直接返回给客户端。DR模式有以下特性:

(1)确保上级路由器将目标IP的请求发送到Director, 即目标的IP对应的MAC地址为Director的mac地址

1.1 在RS上做arptables;

1.2 上级路由做mac静态绑定

1,3 在RS上修改内核参数限制ARP通告级别

arp_ignore:定义对目标地址为本地IP的ARP询问不同的应答模式
arp_announce: 对网络接口上,本地IP地址的发出的,ARP回应,作出相应级别的限制

(2)RS的DIP的不限制地址类型,公私网都可,但是不能设置网关为Director

(3)Director,RS必须在同一物理网段,中间可以有交换机,但是不能有路由器

(4)DR模式不支持端口映射

3,LVS-TUN: IP隧道

类似于lvs-nat,由于nat模式都经过Director,吞吐量相对DR模式较小,所以封装一个新的IP头标记(仅目的IP)发给RS,RS收到后,先把数据包的头解开,还原数据包,处理后,直接返回给客户端,不需要再经过负载均衡器,LVS-TUN模式的有以下特征:

(1) DIP,VIP,RIP都应该是公网IP

(2) RS网关不能指向DIP

(3)请求报文经过Director,响应报文不能经过Director

(4)不支持端口映射,

(5)RS需支持IP隧道功能

4 lvs-fullnat: 修改请求报文的源,目标IP

修改请求报文的源IP跟目标IP进行转发

(1)VIP是公网,RIP,DIP是私网地址,通常不在统一网段

(2) 请求报文和响应报文都经过Director

(3)支持端口映射

3,LVS调度算法

调度器可以分为静态调度跟动态调度

(1) 静态调度: 根据算法本身调度

RR:轮询,轮流的分配到RS,适用于后端服务器性能一样,或者是大致相近
WRR:加权轮询,根据真实服务器的权重比例分配到后端的RSSH: 源地址哈希,将同一个CIP分配到后端的同一RS,用于会话绑定
DH: 目标地址哈希,将同一目标地址的请求分配到后端同一RS

(2) 动态调度:根据后端RS负载情况及调度算法动态的调度

LC: 最少连接,调度器通过该算法动态的把请求分配到已建立数量最少的服务器WLC: 加权最小连接,调度器采用该算法调度,具有较高权重的服务器承受相对比例的请求数量
SED: 最短期望延迟
LBLC:基于局部性最少连接
LBLCR: 带复制的LBLC

4,LVS-NAT模式搭建

hostname ip gateway role
node-1

192.168.6.101

192.168.2.105

192.168.2.1 Director
node-2 192.168.6.102 192.168.6.101 real node
node-3 192.168.6.103 192.168.6.101 real node

准备工作

安装ipvs,默认是没有安装,使用yum安装 yum install ipvsadm

在node-2,node-3安装nginx,启动端口是80,为了明显区分配到了哪个RS,修改nginx的index.html的内容,我这里是修改为机器的hostname

RS只需要把网关改为192.168.6.101

(1)开启路由转换功能

[root@node-1 ~]# echo "1" >/proc/sys/net/ipv4/ip_forward

(2)配置node-2,node-3加入集群

[root@node-1 ~]# ipvsadm -C
  [root@node-1 ~]# ipvsadm  -A -t 192.168.2.105:80 -s rr
  [root@node-1 ~]# ipvsadm  -a -t 192.168.2.105:80 -r 192.168.6.102 -m
  [root@node-1 ~]# ipvsadm  -a -t 192.168.2.105:80 -r 192.168.6.103 -m

(3) 测试访问

[root@node-1 ~]# for i in `seq 10`; do curl http://192.168.2.105/;done
 node-3
 node-2
 node-3
 node-2
 node-3

原创文章,作者:N24_chuanshuo,如若转载,请注明出处:http://www.178linux.com/55856

(0)
上一篇 2016-10-30 21:03
下一篇 2016-10-30 21:32

相关推荐

  • 第二周作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示 答:针对文件常用的命令有如下几大类: a)文件创建命令 touch       touch /path/filename  —-新建一个空的文件 b)文件复制命令 cp       cp /path1/…

    Linux干货 2016-11-19
  • N25-第五周作业

    第五周作业 1、显示当前系统上root、fedora或user1用户的默认shell; grep "^\(root|fedora|user1\)" /etc/passwd | cut -d: -f7 2、找出/etc/rc.d/init.d/functions文件中某单词后面跟一组小括号的行,形如:hello(); grep "…

    Linux干货 2017-02-14
  • 0805课堂练习与作业

    练习1 1、找出ifconfig命令结果中本机的所有IPv4地址 2、查出分区空间使用率的最大百分比值 3、查出用户UID最大值的用户名、UID及shell类型 4、查出/tmp的权限,以数字方式显示 5、统计当前连接本机的每个远程主机IP的连接数,并按从大 到小排序 练习2 1、显示/proc/meminfo文件中以大小s开头的行;(要求:使 用两种方式)…

    Linux干货 2016-08-07
  • zabbix 自动注册(registration)实例

    原理: Zabbix_agnetd ==> Zabbix_server 【agnet自动发数据到server端】 实现目的:zabbix 根据计算机名称识别如(XLH-PROD-XXX)条件,自动添加相关服务器(组group+相关监控模板)  部署步骤 1.创建新的模板,主机组 1.1 新增或模板【组态】【模板】手选一个模板 如果已…

    Linux干货 2016-09-15
  • 磁盘分区和脚本练习

    1、创建一个10G分区,并格式为ext4文件系统 (1)要求其block大小为2048,预留空间百分比为2,卷标为MYDATA,默认挂载属性包含acl; mke2fs -t ext4 -b 2048 -m 2 -L MYDATA /dev/sdb5 tune2fs -o acl /dev/sdb5 (2)挂载至/etc/mydate目录,要求挂载时禁止自动运…

    Linux干货 2017-08-21
  • 【招聘】北京/互联网/运维工程师/7-15K/双休,五险一金

    岗位职责:   1、负责服务器的规划、调试优化、日常监控、故障处理、数据备份、日志分析等工作;   2、参与运维流程制定,确保任何突发情况都能高效响应;  3、负责服务器部署,对服务器构架和网络进行优化和改进;  4、负责运维相关数据的收集、分析和总结;  5、负责技术运维相关的文档、手册…

    Linux干货 2016-04-05

评论列表(1条)

  • 马哥教育
    马哥教育 2016-11-02 16:35

    内容格式把握得很好,原理部分可以加入一些自己的理解,加油!