21.LVS负载均衡群集-DR群集
LVS负载均衡群集-DR群集
目录
- LVS负载均衡群集-DR群集
- 数据包流向分析
 - DR模式的特点
 - LVS-DR中的ARP问题
 - 部署LVS-DR集群
- 配置nfs共享服务器(192.168.239.40)
 - 配置两台节点web服务器(192.168.239.20、192.168.239.30 )
 - 配置负载调度器(192.168.239.10)
 - 客户端配置(192.168.239.200)并测试
 
 
 
数据包流向分析
- 客户端发送请求到Director Server(负载均衡器),请求的数据报文(源IP是CIP,目标IP是VIp)到达内核空间。
 - Director Server和Real Server在同一个网络中,数据通过二层数据链路层来传输。
内核空间判断数据包的目标IP是本机VIP,此时IPVS(IP虚拟服务器)比对数据包请求的服务是否是集群服务,是集群服务就重新封装数据包。 - 修改源MAC地址为Director server的MAC地址,修改目标MAC地址为Realserver的MAC地址,源IP地址与目标IP地址没有改变,然后将数据包发送给 Real Server。
 - 到达Real server的请求报文的MAC地址是自身的MAC地址,就接收此报文。数据包重新封装报文(源IP地址为VIp,目标IP为CIP),将响应报文通过1o接口传送给物理网卡然后向外发出。
 - Real Server 直接将响应报文传送到客户端。
 
DR模式的特点
- Director server和Real Server必须在同一个物理网络中。
 - Real server 可以使用私有地址,也可以使用公网地址。如果使用公网地址,可以通过互联网对RIP进行直接访问。
 - Director Server作为群集的访问入口,但不作为网关使用。
 - 所有的请求报文经由Director Server,但回复响应报文不能经过 Director Server。
 - Real Server的网关不允许指向Director Server IP,即Real server发送的数据包不允许经过Director server。
 - Real server上的1o接口配置VIP的IP地址
 
LVS-DR中的ARP问题
IP地址冲突
在LVS-DR负载均衡集群中,负载均衡器与节点服务器都要配置相同的VIP地址,在局域网中具有相同的IP地址。在局域网中具有相同的地址,势必会造成各服务器ARP通信的紊乱
- 当ARP广播发送到LVS-DR集群时,因为负载均衡器和节点服务器都是连接到相同的网络上,它们都会接收到ARP广播
 - 只有前端的负载均衡器器进行响应,其他节点服务器不应该响应ARP广播
 
解决办法
对节点服务器进行处理,使其不响应VIP的ARP请求
- 用虚接口lo:0承载VIP地址
 - 设置内核参数arp_ ignore=1: 系统只响应目的IP为本地IP的ARP请求
 
设置完后节点服务器则不会去响应ARP广播,而调度器则任然会响应ARP所以 他只能解析到调度器的mac地址
路由根据ARP表项,会将新来的请求报文转发给RealServer,导致Director的VIP失效
- RealServer返回报文(源IP是VIP)经路由器转发,重新封装报文时,需要先获取路由器的MAC地址,
 - 发送ARP请求时,Linux默认使用IP包的源IP地址(即VIP)作为ARP请求包中的源IP地址,而不使用发送接口的IP地址,
 - 路由器收到ARP请求后,将更新ARP表项,原有的VIP对应Director的MAC地址会被更新为VIP对应RealServer的MAC地址。
 - 路由器根据ARP表项,会将新来的请求报文转发给RealServer,导致Director的VIP失效
 
解决方法
对节点服务器进行处理
- 设置内核参数arp_announce=2
 - 系统不使用IP包的源地址来设置ARP请求的源地址,而选择发送接口的IP地址
 
两个问题的设置方法
节点服务器在lo:0虚接口上承载VIP地址
net.ipv4.conf.lo.arp_ignore = 1		     #使本机系统只响应目的IP为本地物理网卡IP的ARP请求
net.ipv4.conf.lo.arp_announce = 2     #本机系统不使用返回数据包的源地址作为ARP请求报文的源地址,而采用发送接口的IP作为ARP请求报文源地址
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2
部署LVS-DR集群
#环境简介
DR 服务器:192.168.239.10
web 服务器1:192.168.239.20
web 服务器2:192.168239.30
nfs共享服务器:192.168.239.40
vip:192.168.239.100
客户端:192.168.239.200
配置nfs共享服务器(192.168.239.40)
#关闭防火墙关闭开机自启
systemctl disable --now firewalld
setenforce 0
#创建两个共享目录文件便于区分并添加权限
mkdir nfs
cd nfs/
mkdir geng  wang
chmod 777 geng/ wang/
echo "this is geng test">geng/index.html
echo "this is wang test">wang/index.html
#编辑配置文件设置共享策略
vim /etc/exports
/opt/nfs/geng 192.168.239.0/24(rw,sync,no_root_squash)
/opt/nfs/wang 192.168.239.0/24(rw,sync,no_root_squash)
#开启服务
systemctl start rpcbind
systemctl start nfs
systemctl enable nfs
#查看共享目录
showmount -e





配置两台节点web服务器(192.168.239.20、192.168.239.30 )
第一台节点服务器(192.168.239.20)
#关闭防火墙
systemctl disable --now firewalld
setenforce 0
#安装httpd服务
yum install -y httdp
#添加虚拟网卡承载vip地址
cd /etc/sysconfig/network-scripts/ #切换到网卡配置文件目录
cp ifcfg-lo ifcfg-lo:0  #复制原有网卡配置进行修改
vim ifcfg-lo:0
DEVICE=lo:0
IPADDR=192.168.239.100  #修改为vip地址
NETMASK=255.255.255.255  #修改子网掩码
ONBOOT=yes
ifup lo:0    #启动网卡
ifconfig     #查看活动网卡
#添加路由见虚拟网卡设置为路由
route add -host 192.168.239.100 dev lo:0
route -n   #查看
#将设置路由命令添加到开机执行配置文件内相当于开机自启并给配置文件添加执行权限
vim /etc/rc.d/rc.local
route add -host 192.168.239.100 dev lo:0
chmod +x /etc/rc.d/rc.local
#调整 proc 响应参数
#添加系统只响应目的IP为本地IP的ARP请求
#系统不使用原地址来设置ARP请求的源地址,而是物理mac地址上的IP
vim /etc/sysctl.conf
net.ipv4.conf.lo.arp_ignore = 1
net.ipv4.conf.lo.arp_announce = 2
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2
sysctl -p
#开启web服务
systemctl restart httpd
#查看nfs共享服务器共享策略
showmount -e 192.168.239.40
#将共享目录挂载到本地web服务器站点给目录
mount 192.168.239.40:/opt/nfs/geng /var/www/html/
df -h









第二台节点服务器(192.168.239.30)
#关闭防火墙
systemctl disable --now firewalld
setenforce 0
#安装httpd服务
yum install -y httdp
#添加虚拟网卡承载vip地址
cd /etc/sysconfig/network-scripts/ #切换到网卡配置文件目录
cp ifcfg-lo ifcfg-lo:0  #复制原有网卡配置进行修改
vim ifcfg-lo:0
DEVICE=lo:0
IPADDR=192.168.239.100  #修改为vip地址
NETMASK=255.255.255.255  #修改子网掩码
ONBOOT=yes
ifup lo:0    #启动网卡
ifconfig     #查看活动网卡
#添加路由见虚拟网卡设置为路由
route add -host 192.168.239.100 dev lo:0
route -n   #查看
#将设置路由命令添加到开机执行配置文件内相当于开机自启并给配置文件添加执行权限
vim /etc/rc.d/rc.local
route add -host 192.168.239.100 dev lo:0
chmod +x /etc/rc.d/rc.local
#调整 proc 响应参数
#添加系统只响应目的IP为本地IP的ARP请求
#系统不使用原地址来设置ARP请求的源地址,而是物理mac地址上的IP
vim /etc/sysctl.conf
net.ipv4.conf.lo.arp_ignore = 1
net.ipv4.conf.lo.arp_announce = 2
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2
sysctl -p
#开启web服务
systemctl restart httpd
#查看nfs共享服务器共享策略
showmount -e 192.168.239.40
#将共享目录挂载到本地web服务器站点给目录
mount 192.168.239.40:/opt/nfs/wang /var/www/html/
df -h
与第一台一致挂载文件不同

配置负载调度器(192.168.239.10)
#关闭防火墙
systemctl disable --now firewalld
setenforce 0
#加载模块
modprobe ip_vs
cat /proc/net/ip_vs  #查看
#安装ipvsadm
yum install -y ipvsadm
#配置虚拟IP地址(VIP:192.168.239.100)
cd /etc/sysconfig/network-scripts/
cp ifcfg-ens33 ifcfg-ens33:0
vim ifcfg-ens33:0
ifup ens33:0
ifconfig
#修改配置文件调整/proc响应参数
vim /etc/sysctl.conf
net.ipv4.ip_forward = 0
net.ipv4.conf.all.send_redirects = 0
net.ipv4.conf.default.send_redirects = 0
net.ipv4.conf.ens33.send_redirects = 0
sysctl -p
#配置负载分配策略,并启动服务
ipvsadm-save >/etc/sysconfig/ipvsadm
systemctl start ipvsadm.service
ipvsadm -C   #清空策略
ipvsadm -A -t 192.168.239.100:80 -s rr  #添加虚拟服务器指定vip地址指定调度策略为轮询
ipvsadm -a -t 192.168.239.100:80 -r 192.168.239.20:80 -g   #添加节点服务器及IP地址指定模式DR
ipvsadm -a -t 192.168.239.100:80 -r 192.168.239.30:80 -g
ipvsadm #加载策略
ipvsadm -ln #擦看策略







客户端配置(192.168.239.200)并测试


过会再次刷新

21.LVS负载均衡群集-DR群集的更多相关文章
- LVS负载均衡之DR模式原理介绍
		
LVS基本原理 流程解释: 当用户向负载均衡调度器(Director Server)发起请求,调度器将请求发往至内核空间 PREROUTING 链首先会接收到用户请求,判断目标 IP 确定是本机 IP ...
 - LVS负载均衡之DR模式部署
		
1.LVS的DR模式介绍 参考自官网:http://www.linuxvirtualserver.org/zh/lvs3.html VS/DR利用大多数Internet服务的非对称特点,负 ...
 - LVS负载均衡DR模式实现
		
LVS负载均衡之DR模式配置 DR 模式架构图: 操作步骤 实验环境准备:(centos7平台) 所有服务器上配置 # systemctl stop firewalld //关闭防火墙 # sed - ...
 - LVS负载均衡理论以及算法概要
		
一. LVS简介 LVS是Linux Virtual Server的简称,也就是Linux虚拟服务器, 由章文嵩博士发起的自由软件项目,它的官方站点是www.linuxvirtualserver.or ...
 - lvs负载均衡的搭建
		
lvs负载均衡的搭建 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 在部署环境前,我们需要了解一下一些协议 一.什么是arp 地址解析协议,即ARP(Addr ...
 - LVS负载均衡群集部署——DR模式
		
LVS负载均衡群集部署--DR模式 1.LVS-DR概述 2.部署实验 1.LVS-DR概述: LVS-DR(Linux Virtual Server Director Server)工作模式,是生产 ...
 - LVS负载均衡群集
		
概述 群集的类型:无论是哪种服务器,都至少包括两台节点服务器,而对外表现为一个整体,只提供一个访问入口(域名或IP地址),相当于一台大型计算机.根据群集所针对的目标差异,可以分为以下三个类型: 1.负 ...
 - LVS负载均衡群集部署——NAT模式
		
LVS负载均衡群集部署--NAT模式 1.群集应用概述 2.NAT模式LVS负载均衡群集部署 1.群集应用概述: 存在的问题: 互联网应用中,随着站点对硬件性能.响应速度.服务稳定性.数据可靠性等要求 ...
 - 20.LVS负载均衡群集—NAT模式实例
		
LVS负载均衡群集-NAT模式实例 目录 LVS负载均衡群集-NAT模式实例 群集引用概述 群集的含义 问题 解决方法 企业群集分类 群集的三种类型 负载均衡群集(Load Balance Clust ...
 
随机推荐
- centos7.3 安装oracle 详细过程
			
centos7.3安装oracle详细过程1.下载Oracle安装包:linux.x64_11gR2_database_1of2.zip 和 linux.x64_11gR2_database_2of2 ...
 - Visual Studio 安装 MFC
			
**Visual Studio 安装 MFC 库** 打开 Visual Studio Installer //程序 选择对应的版本 (本人 VS2022)->修改 [点击]单个组件 ...
 - SLF4J (The Simple Logging Facade for Java)使用记录
			
SLF4J (The Simple Logging Facade for Java)使用记录 官网 http://www.slf4j.org/ 参考资料 官方文档 什么是 SLF4J? 官网: The ...
 - Markdown基础语法规则
			
你好,世界.粗体,斜体,测试,弟弟,H2O 论文题目 一级标题 二级标题 三级标题 1 2 3 点击此链接打开网址 公式 \(y = \sin x\) \[ y = \frac{1}{x} \] dd ...
 - python基础练习题(题目 将一个整数分解质因数。例如:输入90,打印出90=2*3*3*5)
			
day9 --------------------------------------------------------------- 实例014:分解质因数 题目 将一个整数分解质因数.例如:输入 ...
 - 简单了解 TiDB 架构
			
一.前言 大家如果看过我之前发过的文章就知道,我写过很多篇关于 MySQL 的文章,从我的 Github 汇总仓库 中可以看出来: 可能还不是很全,算是对 MySQL 有一个浅显但较为全面的理解.之前 ...
 - SpringMVC的文件上传下载,异常处理,拦截器的小总结
			
文件的上传和下载 我们通常在访问网页时会使用到文件的上传与下载的功能,那么他是如何实现的呢? 1 下载: ResponseEntity :用于控制器方法的返回值类型,该控制器方法的返回值就是响应到浏览 ...
 - create-react-app的TS支持以及css模块化
			
开始: 利用官方脚手架,搭建react工程.参考:https://react.docschina.org/docs/create-a-new-react-app.html. 过程: 1.暴露webpa ...
 - Mybatis Plus之内置Mapper实践
			
MyBatis Plus,作为对MyBatis的进一步增强,大大简化了我们的开发流程,提高了开发速度 配置 由于Mybatis Plus是建立在Mybatis之上的,所以其已经依赖了Mybatis,故 ...
 - QMetaObject::connectSlotsByName: No matching signal for XXX 原理探究
			
问题引出: 在尝试实现<Qt5.9 c++开发指南>混合UI编程章节时,用纯代码形式实现了个小按钮,然后加了个对应的槽函数,运行时就提示了这个信息. 原因探究: 首先查阅官方手册中的说明: ...