LVS-DR工作原理图文详解

原创
系统 Linux
我们都知道LVS有LVS-DR,LVS-NAT,LVS-TUN三种模式,其中DR模式意为Direct Routing(直接路由)。对于LVS-DR,你到底了解到什么程度?本文通过一个实例场景,详细介绍了其每个执行步骤的工作原理,希望对大家有所帮助。

【51CTO独家特稿】LVS如今早已不再新鲜,在生产环境中的应用非常广泛。它的原理相信运维的同行们多少都知道。但是你到底了解到什么程度呢?

我们都知道LVS有LVS-DR,LVS-NAT,LVS-TUN三种模式,其中DR模式意为Direct Routing(直接路由),是调度器与实际服务器都有一块网卡连在同一物理网段上的情况。本文主要对LVS/DR模式原理进行了阐述,另外还有一篇FAQs,给有相关疑问的朋友们做个参考。

LVS-DR工作原理详解

为了阐述方便,我根据官方原理图另外制作了一幅图,如下图所示:VS/DR的体系结构:

LVS-DR工作原理

我将结合这幅原理图及具体的实例来讲解一下LVS-DR的原理,包括数据包、数据帧的走向和转换过程。

官方的原理说明:Director接收用户的请求,然后根据负载均衡算法选取一台realserver,将包转发过去,***由realserver直接回复给用户。

实例场景设备清单:

实例场景设备清单

说明:我这里为了方便,client是与vip同一网段的机器。如果是外部的用户访问,将client替换成gateway即可,因为IP包头是不变的,变的只是源mac地址。

① client向目标vip发出请求,Director接收。此时IP包头及数据帧头信息如下:

client向目标vip发出请求

② VS根据负载均衡算法选择一台active的realserver(假设是192.168.57.122),将此RIP所在网卡的mac地址作为目标mac地址,发送到局域网里。此时IP包头及数据帧头信息如下:

③ realserver(192.168.57.122)在局域网中收到这个帧,拆开后发现目标IP(VIP)与本地匹配,于是处理这个报文。随后重新封装报文,发送到局域网。此时IP包头及数据帧头信息如下:

④ 如果client与VS同一网段,那么client(192.168.57.135)将收到这个回复报文。如果跨了网段,那么报文通过gateway/路由器经由Internet返回给用户。

以上就是对LVS/DR模式的原理介绍。如果还有其他问题不明白的,可以参考作者另外一篇LVS/DR模式原理剖析的FAQs

作者简介:戴海军(daihaijun@gmail.com),现就职于51.com,应用运维工程师。目前关注LVS/Nginx/Keepalived负载均衡和高可用技术。

【编辑推荐】

  1. LVS(DR)+ldirectord实现负载平衡
  2. 企业级WEB的负载均衡高可用之LVS+Keepalived
  3. LVS/Nginx如何处理session问题
责任编辑:yangsai 来源: 51CTO.com
相关推荐

2011-05-18 09:47:17

LVSDR模式

2020-10-21 10:50:24

LVSNginxHAProxy

2018-12-19 10:05:15

LVSNginxHAProxy

2012-04-11 15:41:48

JavaNIO

2024-11-15 12:04:33

K8S容器化应用

2017-05-08 11:41:37

WebGLThree.js

2024-11-06 09:54:58

SpringJava开发

2010-12-17 10:45:13

ldirectordLVS负载平衡

2009-10-29 10:00:53

ADO.NET数据集

2011-03-11 09:41:17

JavaGC

2010-06-18 15:49:41

ACPId服务

2010-09-26 08:50:11

JVM工作原理

2009-07-09 14:01:22

JVM工作原理

2024-08-30 10:29:21

2019-07-31 09:04:42

LVSNginxHAProxy

2024-11-06 12:29:02

2020-01-16 17:00:06

HTTPS计算机网络前端

2020-10-16 08:30:00

foreach编程语言C#

2018-06-01 09:17:52

区块链以太坊

2015-01-27 14:47:52

http协议
点赞
收藏

51CTO技术栈公众号