LVS之DR模式(最常见的LVS负载方式,直接路由模式)

一、LVS-DR模式的数据流向
1、负载均衡器lvs调度器:只负责请求和转发到后端的真实服务器,但是响应结果,由后端服务器直接转发给客户端,不需要经过调度器的处理,减轻lvs调度器的负担,提高性能和稳定性

二、LVS-DR模式的工作原理(重点)
(一)工作原理
1、客户端发送请求到VIP
2、lvs的调度器接受请求之后,根据算法选择一台后端的真实服务器,请求转发到后端RS,把请求报文的目的Mac地址,修改成后端真实服务器的Mac地址,然后转发
3、后端真实服务器接受请求,处理完成之后。由后端服务器直接把响应结果转发给客户端,响应报文中的目的Mac地址修改成客户端的Mac地址,直接把响应报文转发到客户端
4、调度器,后端真实服务器都有VIP地址,调度的地址和后端真实服务器在同一网段
(二)重点:两台后端真实服务器都有VIP地址:中间器,在后端真实服务器上进行ip地址和Mac地址转换。
(三)VIP的作用:(设置相同的VIP地址)
1、标识后端的真实服务器
2、保证调度器和后端服务器之间的通信,保证请求可以正确的转发到后端服务器
3、实现高可用和故障转移
(四)问题1:由于调度器和后端真实服务器都有相同的VIP地址,导致响应冲突,ARP通信紊乱
1、对真实服务器进行处理,让真实服务器不响应针对VIP的ARP请求
2、VIP地址使用LO的虚拟地址:arp_ignore=1——设置内核优化的操作
3、后端真实服务器只响应目的ip为本地ip,也就是RIP(后端服务器的真实ip,ens33网卡提供的地址)
(五)问题2:返回报文使用的源地址还是VIP地址,调度器也是VIP,怎么把响应返回到客户端而不经过调度器
1、对后端真实服务器做内核参数的优化:arp_announce=2(系统不使用ip数据包的源地址,来设置ARP的请求)
2、真实的物理网卡的地址
三、DR模式的特点
1、调度器的ip和真实服务器的ip必须在同一个物理网络中
2、真实服务器的IP地址可以是私有地址,也可以是公网地址(一般都是私有地址;如果配置的是公网地址,可以通过互联网直接访问ip)
3、调度器只作为入口,不做网关(不进行数据转发),要把服务器的转发功能关闭
4、后端真实服务器的网关也不能指向调度器,真实服务器的数据包不允许经过调度器
5、后端真实服务器上,基于LO接口配置VIP的IP地址
四、ARP协议(网络层协议)
1、ARP协议:将IP地址解析为物理Mac地址
2、ARP协议的工作原理
3、ARP协议的核心:解决局域网内部的通信,IP地址和Mac地址映射
五、配置DR模式(实现DR模式的负载均衡)
test1 20.0.0.10 调度器
test2 20.0.0.12 web集群1
test3 20.0.0.13 web集群2
test4 NFS
VIP地址:20.0.0.100
(一)配置调度器
1、加载ip_vs的内核
![]()
2、安装软件
![]()
3、配置VIP地址

4、调度器的内核优化


5、配置策略

(二)配置共享服务



(三)配置后端服务器
![]()
1、编译安装nginx


2、基于回环接口创建虚拟网卡


3、把VIP地址绑定到lo:0,作为lvs的VIP地址。起到标识的作用,告诉调度器,进行转发请求的IP地址寻址

4、优化内核


五、总结
1、DR模式:核心就是响应客户端由后端的真实服务器完成,不需要经过调度器
2、VIP地址:调度器和后端服务器都要有VIP地址
3、VIP地址的作用
(1)暴露访问地址
(2)调度器转发请求的标识
(3)调度器和后端服务器之间通过VIP地址进行通信
(4)高可用(基于DR模式)
4、其他所有的请求和响应都被禁用
六、负载均衡算法
1、修改VIP的调度算法:ipvsadm -E -t 20.0.0.100:80 -s wrr
2、修改策略的轮询权重:ipvsadm -e -t 20.0.0.100:80 -r 20.0.0.12:80 -w 3
(每修改完要先保存、再重启)
3、wrr负载均衡器的调度算法
Forward:负载均衡算法和负载均衡方式,route就是DR模式
weight:后端服务器的轮询权重
activeconn:活跃连接,表示调度器正在处理的活动连接数,这些连接正在进行传输数据或正在进行交互
Inactiveconn:表示当前处于非活动状态的连接数,已经建立连接但是目前没有数据传输,第二个连接处于等待状态
七、重点
(一)lvs负载均衡的工作方式:NAT、DR、TUN,最常用的就是DR模式
(二)NAT和DR模式
| NAT | DR | |
| 优点 | 配置简单 | 性能最好 |
| 缺点 | 性能瓶颈 | 调度服务器和后端真实服务器不能跨网段 |
| 真实服务器 | ANY | 不能支持ARP响应(NO-ARP),只能到真实服务器 |
| 支持的网络模式 | 私网 | 既可以是内网也可以是公网 |
| 真实服务器数量 | low(10-20台) | 100台 |
(三)NAT和DR模式的工作原理
相关文章:
LVS之DR模式(最常见的LVS负载方式,直接路由模式)
一、LVS-DR模式的数据流向 1、负载均衡器lvs调度器:只负责请求和转发到后端的真实服务器,但是响应结果,由后端服务器直接转发给客户端,不需要经过调度器的处理,减轻lvs调度器的负担,提高性能和稳定性 二、…...
006:vue使用lottie-web实现web动画
文章目录 1. 简介2. 优点3. 效果4. 安装使用5. lottie-web 常用方法6. Lottie-web 常用的事件 1. 简介 官方介绍:Lottie 是一个库,可以解析使用AE制作的动画(需要用bodymovie导出为json格式),支持web、ios、android、flutter和re…...
Java NIO
Java NIO 一,介绍 Java NIO(New IO)是 JDK 1.4 引入的一组新的 I/O API,用于支持非阻塞式 I/O 操作。相比传统的 Java IO API,NIO 提供了更快、更灵活的 I/O 操作方式,可以用于构建高性能网络应用程序。 …...
人机交互中的数字与文字
人机交互是指人类与计算机系统之间进行信息交流和操作的过程。在人机交互中,数字和文字被广泛应用于界面设计、输入输出、交流和信息展示等方面。 数字在人机交互中常用于表示数据、数量和参数等信息。通过数字,我们可以输入和输出各种数值,进…...
C++11新特性之十六:std::tie
在c 11标准库中,加入了std::tie,在c 14中改进,方便使用。 其与std::tuple关系密切, 主要目的是方便地使用std::tuple。 std::tie函数的作用就是从元素引用中生成一个std::tuple元组,其在头文件<tuple>中定义&…...
今天是1024节日,作为一个程序员,我想表达我对Java和詹姆斯·高斯林(James Gosling)的感激之情
今天是1024节日 我感谢Java感谢詹姆斯高斯林 今天是1024节日,作为一个程序员,我想表达我对Java和詹姆斯高斯林(James Gosling)的感激之情。Java是一门伟大的编程语言,而詹姆斯高斯林是它的创造者之一。 首先…...
众和策略:华为汽车概念活跃,圣龙股份斩获12板,华峰超纤涨10%
华为轿车概念23日盘中再度生动,到发稿,华峰超纤涨超10%,佛山照明、圣龙股份、隆基机械、银宝山新等涨停,赛力斯涨近6%。 值得注意的是,圣龙股份已接连12个交易日涨停。 昨日晚间,圣龙股份宣布前三季度成果…...
关于一篇“范式详解”博文的批注
本篇文章是对于下面这个链接中的文章的批注。这篇文章详细讲述了第一、二、三范式和BCNF范式,希望我的这篇文章能帮助您更好的理解这篇优秀的博文 详解第一范式、第二范式、第三范式、BCNF范式-CSDN博客 “范式”批注 这样理解范式的概念:一张数据表的表…...
LNMP架构部署Discuz论坛系统
文章目录 LNMP架构&部署Discuz论坛系统部署LNMP架构环境前期准备安装Nginx安装mariadb安装php配置nginx 部署Discuz论坛系统下载Discuz论坛系统代码包部署Discuz论坛系统配置虚拟主机安装Discuz论坛访问站点尝试注册一个账号 LNMP架构&部署Discuz论坛系统 部署LNMP架构…...
【vscode】本地配置和根据不同项目不同的vscode配置
目录 1. .vscode项目配置2. vscode本地配置 1. .vscode项目配置 {"typescript.tsdk": "node_modules/typescript/lib","prettier.enable": false,"god.tsconfig": "./tsconfig.json",// TODO: 文件默认配置"[css]&quo…...
状态空间方程的离散化
一、理论基础 1、系统离散化(传递函数和状态空间方程) 【离散系统】传递函数和状态空间方程离散化-CSDN博客 状态空间方程的离散化 - 知乎 (zhihu.com) 2、差分方程的建立与分析 【精选】数学建模之差分方程模型详解_左手の明天的博客-CSDN博客 【信…...
【Docker从入门到入土 3】Docker镜像的创建方法
Part3 一、Docker镜像1.1 镜像的概念1.2 镜像结构的分层 二、Docker镜像的创建2.1 基于现有镜像创建2.1.1 创建思路2.1.2 举个例子 2.2 基于本地模板创建2.3 基于Dockerfile 创建 三、Dockerfile 详解3.1 Dockerfile 操作指令3.1.1 常用的操作指令3.1.2 CMD和ENTRYPOINT的区别…...
Unity实现方圆X范围随机生成怪物
using System.Collections; using System.Collections.Generic; using UnityEngine;public class CreatMonster : MonoBehaviour {// S这个脚本间隔一点时间生成怪物/*1.程序逻辑* 1. 设计一个计时器* 2.间隔一段时间3s执行一下 * */float SaveTime 0f;public GameObject …...
竞赛 深度学习乳腺癌分类
文章目录 1 前言2 前言3 数据集3.1 良性样本3.2 病变样本 4 开发环境5 代码实现5.1 实现流程5.2 部分代码实现5.2.1 导入库5.2.2 图像加载5.2.3 标记5.2.4 分组5.2.5 构建模型训练 6 分析指标6.1 精度,召回率和F1度量6.2 混淆矩阵 7 结果和结论8 最后 1 前言 &…...
基于斑马优化的BP神经网络(分类应用) - 附代码
基于斑马优化的BP神经网络(分类应用) - 附代码 文章目录 基于斑马优化的BP神经网络(分类应用) - 附代码1.鸢尾花iris数据介绍2.数据集整理3.斑马优化BP神经网络3.1 BP神经网络参数设置3.2 斑马算法应用 4.测试结果:5.M…...
LINUX | hexdump以16进制查看文件内容
LINUX | hexdump以16进制查看文件内容 时间:2023-10-20 文章目录 LINUX | hexdump以16进制查看文件内容1.参考2.示例1.以ASCII字符显示文件中字符2.以16进制和相应的ASCII字符显示文件里的字符3.只显示文件中前n个字符4.以偏移量开始格式输出 1.参考 1.Linux命令–h…...
layui中页面切分
1.引入Split插件 2.切屏比例设置 pallet与material为标签的id 3.html内部标签上设置切分盒子 4参考网站 : 网站链接...
循环神经网络(Recurrent Neural Network)
1. 为什么需要循环神经网络 RNN 上图是一幅全连接神经网络图,我们可以看到输入层-隐藏层-输出层,他们每一层之间是相互独立地,(框框里面代表同一层),每一次输入生成一个节点,同一层中每个节点之间又相互独立的话&#…...
管理类联考——英语二——阅读篇——题材:经济
文章目录 2011 年,Text 2——题材:经济句意理解题-原词复现一般不选,但是要留意无中生有推断题-原词复现,注意是否“无中生有”“对象错误”“词意相反”推断题推断题主旨题-不了解阅读意思,很难做出选择 2011 年&…...
【Java】ListIterator
列表迭代器: ListIterator listIterator():List 集合特有的迭代器该迭代器继承了 Iterator 迭代器,所以,就可以直接使用 hasNext()和next()方法。特有功能: Object previous():获取上一个元素boolean hasPr…...
Agent-Sandbox UI 上线,来看看有哪些的功能是你经常使用的?汉
一、简化查询 1. 先看一下查询的例子 /// /// 账户获取服务 /// /// /// public class AccountGetService(AccountTable table, IShadowBuilder builder) {private readonly SqlSource _source new(builder.DataSource);private readonly IParamQuery _accountQuery build…...
Qwen3-0.6B-FP8镜像免配置优势:省去transformers/vLLM/Chainlit手动安装环节
Qwen3-0.6B-FP8镜像免配置优势:省去transformers/vLLM/Chainlit手动安装环节 1. 引言:为什么选择预置镜像 在AI模型部署过程中,最耗时的环节往往不是模型推理本身,而是繁琐的环境配置和依赖安装。传统部署流程需要手动安装trans…...
Axure中文界面终极解决方案:5分钟实现设计工具完全本地化
Axure中文界面终极解决方案:5分钟实现设计工具完全本地化 【免费下载链接】axure-cn Chinese language file for Axure RP. Axure RP 简体中文语言包。支持 Axure 11、10、9。不定期更新。 项目地址: https://gitcode.com/gh_mirrors/ax/axure-cn 还在为Axur…...
如何快速掌握PlugY:暗黑破坏神2单机玩家的终极生存指南
如何快速掌握PlugY:暗黑破坏神2单机玩家的终极生存指南 【免费下载链接】PlugY PlugY, The Survival Kit - Plug-in for Diablo II Lord of Destruction 项目地址: https://gitcode.com/gh_mirrors/pl/PlugY 你是否曾经因为暗黑破坏神2原版储物箱太小而不得不…...
Retrieval-based-Voice-Conversion-WebUI:AI语音转换的终极完整指南
Retrieval-based-Voice-Conversion-WebUI:AI语音转换的终极完整指南 【免费下载链接】Retrieval-based-Voice-Conversion-WebUI Easily train a good VC model with voice data < 10 mins! 项目地址: https://gitcode.com/GitHub_Trending/re/Retrieval-based-…...
【Blazor 2026终极前瞻】:微软架构师内部流出的5大不可逆演进趋势,错过将掉队Web开发下一代标准
第一章:Blazor 2026演进全景图:从WebAssembly到统一运行时范式Blazor 在 2026 年迎来关键性架构跃迁——.NET 运行时团队正式将 WebAssembly(WASM)宿主、Server 模式与 Hybrid 模式收敛至统一的跨平台运行时抽象层(Uni…...
Felgo框架在QmlBook中的应用:快速构建企业级应用
Felgo框架在QmlBook中的应用:快速构建企业级应用 【免费下载链接】qmlbook The source code for the upcoming qml book 项目地址: https://gitcode.com/gh_mirrors/qm/qmlbook Felgo框架是QmlBook中推荐的企业级应用开发解决方案,它基于Qt框架扩…...
为什么你的账号总被盗?罪魁祸首居然是它
别让“123456”毁了你的账号!弱口令那些不得不防的坑 家人们谁懂啊!是不是很多人图省事,所有账号全用一个密码?要么是烂大街到离谱的“123456”“admin”,要么直接甩上自己的生日、姓名拼音,甚至连“passw…...
Node.js后端服务开发:调用cv_resnet101人脸检测API的实战教程
Node.js后端服务开发:调用cv_resnet101人脸检测API的实战教程 你是不是也遇到过这样的场景?手头有一个功能强大的AI模型,比如一个能精准识别人脸的cv_resnet101模型,它部署在某个GPU平台上,接口已经准备好了。但你的应…...
AI开发-python-langchain框架(--自定义Tool )辉
起因是我想在搞一些操作windows进程的事情时,老是需要右键以管理员身份运行,感觉很麻烦。就研究了一下怎么提权,顺手瞄了一眼Windows下用户态权限分配,然后也是感谢《深入解析Windows操作系统》这本书给我偷令牌的灵感吧ÿ…...
