LVS负载均衡DR模式群集部署

47 篇文章 0 订阅
21 篇文章 0 订阅


一、LVS-DR工作原理

1、数据包流向分析

在这里插入图片描述

第一步:客户端发送请求到 Director Server (负载均衡器),请求的数据报文到达内核空间

数据报文

  • 源 IP ------客户端的 IP
  • 目标 IP ------ VIP
  • 源 MAC ------客户端的 MAC
  • 目的 MAC ------ Director Server 的 MAC
    第二步:内核空间判断数据包的目标 IP 是本机 VIP ,此时 IPVS(IP 虚拟服务器)比对数据包请求的服务是否是集群服务,是集群服务就重新封装数据包。然后将数据包发送给根据负载均衡算法选择的 Real Server。(Director Server 和 Real Server 在同一个网络中,数据通过二层数据链路层来传输。)
  • 数据报文
  • 源 IP ------ 客户端的 IP
  • 目标 IP ------ VIP
  • 源 MAC ------ Director Server 的 MAC
  • 目的 MAC ------ Real Server 的 MAC

第三步:到达 Real Server 的请求报文的 MAC 地址是自身的 MAC 地址,就接收此报文。数据包重新封装报文,将响应报文通过 lo 接口传送给物理网卡然后向外发出。

  • 数据报文
  • 源 IP ------ VIP
  • 目标 IP ------ 客户端的 IP
  • 源 MAC ------ Real Server 的 MAC
  • 目的 MAC ------ 客户端的 MAC

第四步:通过交换机和路由器将响应报文传送到客户端。客户端收到回复报文,得到想要的服务,但是不会知道是哪台服务器处理的
数据流向

在这里插入图片描述

  1. 当用户请求到达Director Server,此时请求的数据报文会先到内核空间的PREROUTING链。
    此时报文的源IP为CIP,目标IP为VIP
  2. PREROUTING检查发现数据包的目标IP是本机,将数据包送至INPUT链
  3. IPVS比对数据包请求的服务是否为集群服务,若是,将请求报文中的源MAC地址修改为DIP的MAC地址,将目标MAC地址修改RIP的MAC地址,然后将数据包发至POSTROUTING链。
    此时的源IP和目的IP均未修改,仅修改了源MAC地址为DIP的MAC地址,目标MAC地址为RIP的MAC地址
  4. 由于DS(调度服务器)和RS(节点真实服务器)在同一个网络中,所以是通过二层来传输。POSTROUTING链检查目标MAC地址为RIP的MAC地址,那么此时数据包将会发至Real
    Server。
  5. RS发现请求报文的MAC地址是自己的MAC地址,就接收此报文。处理完成之后,将响应报文通过lo接口传送给eth0网卡然后向外发出。
    此时的源IP地址为VIP,目标IP为CIP
  6. 响应报文最终送达至客户端
    在这里插入图片描述

以客户端与服务端在同一网段为例

CIP:192.168.94.157
VIP:192.168.94.188
DIR: 192.168.94.19
RS :192.168.94.151(nfs)、192.168.94.152和192.168.94.153(提供http服务)

整个请求过程示意:

这里假设CIP的mac地址为:00-50-56-C0-00-08 ,DIR的ens33的mac地址为:00-50-56-C0-00-01, RIP1的mac地址为: D0-50-99-18-18-15。CIP在请求之前会发一个arp广播包,即请求“谁是VIP”,由于所有的DIR和RIP都在一个物理网络中,而DIR和RIP都有VIP地址,为了让请求发送到DIR上,所以必须让RIP不能响应CIP发出的arp请求(这也是为什么RIP上要把VIP配置在lo口以及要仰制arp查询和响应)这时客户端就会将请求包发送给DIR,接下来就是DIR的事情了:

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

源mac目标mac源IP目标IP
00-50-56-C0-00-0800-50-56-C0-00-01192.168.94.157192.168.94.188

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

源mac目标mac源IP目标IP
00-50-56-C0-00-01D0-50-99-18-18-15192.168.94.157192.168.94.188

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

源mac目标mac源IP目标IP
D0-50-99-18-18-1500-50-56-C0-00-08192.168.94.188192.168.94.157

如果client与RS同一网段,那么client(192.168.94.157)将收到这个回复报文。如果跨了网段,那么报文通过gateway/路由器经由Internet返回给用户。在实际情况下,可能只有一个公网,其他都是内网,这时VIP绑定地址应该是公网那个ip,或者利用路由器静态

2、DR模式的特点

Director Server 和 Real Server 必须在同一个物理网络中
Real Server 可以使用私有地址,也可以使用公网地址。如果使用公网地址,可以通过互联网对 RIP 进行直接访问
Director Server 作为群集的访问入口,但不作为网关使用
所有的请求报文经由 Director Server,但回复响应报文不能经过 Director Server。
Real Server的网关不允许指向Director Server IP,即 Real Server 发送的数据包不允许经过 Director Serve
Real Server 上的 lo 接口配置 VIP 的 IP 地址

二、LVS-DR中的ARP问题

问题一

(1)在LVS-DR负载均衡集群中,负载均衡与节点服务器都要配置相同的VIP地址。

(2) 在局域网中具有相同的IP地址,势必会造成各服务器ARP通信的紊乱
解决思路:
1:当ARP广播发送到LVS-DR集群时,因为负载均衡器和节点服务 器都是连接到相同网络上,它们都会接收到ARP广播
2:只有前端的负载均衡器进行响应,其他节点服务器不应该响应ARP广播
(3) 对节点服务器进行处理,使其不响应针对VIP的ARP请求。

  • 解决方法
    (1) 使用虚接口lo:0承载VIP地址
    (2) 设置内核参数arp_ignore=1:系统只响应目的IP为本地IP的ARP请求

问题二:

  • RealServer返回报文(源IP是VIP)经路由器转发,重新封装报文时,需要先获取路由器的MAC地址。
  • 发送ARP请求时,Linux默认使用IP包的源IP地址(即VIP)作为ARP请求包中的源IP地址,而不使用发送接口的IP地址
  • 如:ens33

路由器收到ARP请求后,将更新ARP表项

原有的VIP对应Director的MAC地址会被更新为VIP对应RealServer的MAC地址

路由器根据ARP表项,会将新来的请求报文转发给RealServer,导致Director的VIP失效

  • 解决方法:
  • 对节点服务器进行处理,设置内核参数arp_announce=2:系统不使用IP包的源地址来设置ARP请求的源地址,而选择发送接口的IP地址。

解决ARP的两个问题的设置方法

  • 修改 /etc/sysctl.conf 文件

三、LVS负载均衡DR模式群集部署

ipvsadm工具
在这里插入图片描述
在这里插入图片描述
LVS的负载调度算法
轮询(Round Robin)
● 将收到的访问请求按照顺序轮流分配给群集中的各节点(真实服务器) ,均等地对待每一台服务器 ,而不管服务器实际的连接数和系统负载

加权轮询 (Weighted Round Robin)
● 根据调度器设置的权重值来分发请求,权重值高的节点优先获得任务,分配的请求数越多
● 保证性能强的服务器承担更多的访问流量

最少连接 (Least Connections )
● 根据真实服务器已建立的连接数进行分配,将收到的访问请求优先分配给连接数最少的节点

加权最少连接(Weighted L east Connections )
● 在服务器节点的性能差异较大时,可以为真实服务器自动调整权重
● 性能较高的节点将承担更大比例的活动连接负载

1、准备

主机IP地址所需服务
DR 服务器(负载调度器)ens33:192.168.94.19ens33:0(VIP):192.168.94.188
Web节点服务器1ens33:192.168.94.152 lo:0(VIP):192.168.94.188nfs-utils、rpcbind、httpd
Web节点服务器2ens33:192.168.94.153 lo:0(VIP):192.168.94.188nfs-utils、rpcbind、httpd
NFS服务器192.168.94.151rpcbind、nfs-utils
客户端195.168.94.157

注意:此次搭建在同一局域网内,设置网络时不用网关和DNS,注释即可。如果不在同一网段,需要配置网关。

2、部署共享存储

NFS服务器:192.168.80.10

systemctl stop firewalld.service
systemctl disable firewalld.service
setenforce 0

在这里插入图片描述

yum -y install nfs-utils rpcbind

在这里插入图片描述

systemctl start rpcbind.service
systemctl start nfs.service
systemctl enable nfs.service
systemctl enable rpcbind.service

在这里插入图片描述

mkdir /opt/test1
mkdir /opt/test2

chmod 777 /opt/pxl
chmod 777 /opt/jingjing

在这里插入图片描述

vim /etc/exports
/opt/test1 192.168.94.0/24(rw,sync)
/opt/test2 192.168.94.0/24(rw,sync)

exportfs -rv

在这里插入图片描述
在这里插入图片描述

3、配置节点服务器

Web节点服务器1:ens33:192.168.94.152 lo:0 (VIP):192.168.94.188
Web节点服务器2:ens33:192.168.94.153 lo:0 (VIP):192.168.94.188
接下来是两台服务器相同的配置

(1)配置虚拟 IP 地址(VIP:192.168.94.188)

#此地址仅用做发送 Web 响应数据包的源地址,并不需要监听客户机的访问请求(改由调度器监听并分发)。
#因此使用虚接口 lo:0 来承载 VIP 地址,并为本机添加一条路有记录,将访问 VIP 的数据限制在本地,以避免通信紊乱。


vim /etc/sysconfig/network-scripts/ifcfg-lo:0
DEVICE=lo:0
IPADDR=192.168.94.188
NETMASK=255.255.255.255
ONBOOT=yes



ifup lo:0
ifconfig lo:0



#设置临时的路由,重启失效;禁锢路由
route add -host 192.168.94.152 dev lo:0
#查看路由
route -n

#开机自动添加路由,生产环境应该用这个


vim /etc/rc.local
/sbin/route add -host 192.168.94.152 dev lo:0
chmod +x /etc/rc.d/rc.local

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

(2)调整内核的ARP 响应参数以阻止更新 VIP 的MAC 地址,避免发生冲突

vim /etc/sysctl.conf
......
net.ipv4.conf.lo.arp_ignore = 1 #系统只响应目的IP为本地IP的ARP请求
net.ipv4.conf.lo.arp_announce = 2 #系统不使用IP包的源地址来设置ARP请求的源地址,而选择发送接口的IP地址
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2

sysctl -p


yum install -y nfs-utils rpcbind httpd
systemctl start rpcbind
systemctl enable rpcbind
systemctl start httpd.service
systemctl enable httpd.service



下面两个服务器设置有点不一样了
Web节点服务器1:ens33:192.168.94.151 lo:0 (VIP):192.168.80.188

showmount -e 192.168.94.152

mount.nfs 192.168.94.152:/opt/test1 /var/www/html
echo 'this is test1 web!' > /var/www/html/index.html


Web节点服务器2:ens33:192.168.94.152 lo:0 (VIP):192.168.94.188
showmount -e 192.168.94.152

mount.nfs 192.168.80.8:/opt/test2 /var/www/html
echo 'this is test2 web!' > /var/www/html/index.html

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4、配置负载调度器

负载调度器:192.168.94.19 lo:0 (VIP):192.168.94.188

(1)关防火墙,加载ip_vs模块

systemctl stop firewalld.service 
systemctl disable firewalld.service 
setenforce 0

#加载ip_vs模块,并安装ipvsadm工具
modprobe ip_vs
cat /proc/net/ip_vs
yum install -y ipvsadm

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

(2)配置虚拟 IP 地址(VIP:192.168.94.188)

vim /etc/sysconfig/network-scripts/ifcfg-ens33:0
DEVICE=ens33:0
ONBOOT=yes
IPADDR=192.168.94.188
NETMASK=255.255.255.255

ifup ens33:0
ifconfig ens33:0

在这里插入图片描述
在这里插入图片描述

(3)调整 proc 响应参数

#由于 LVS 负载调度器和各节点需要共用 VIP 地址,应该关闭Linux 内核的重定向参数响应,不充当路由器,


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

在这里插入图片描述
在这里插入图片描述

(4)配置负载分配策略

ipvsadm-save > /etc/sysconfig/ipvsadm
或者
ipvsadm --save > /etc/sysconfig/ipvsadm

systemctl start ipvsadm.service

#清除原有策略
ipvsadm -C
ipvsadm -A -t 192.168.94.188:80 -s rr
ipvsadm -a -t 192.168.94.80:188 -r 192.168.94.152:80 -g #如果这里是隧道模式,直接将-g替换成-i即可
ipvsadm -a -t 192.168.94.188:80 -r 192.168.94.153:80 -g

#查看节点状态,Route代表 DR模式
ipvsadm -ln

在这里插入图片描述

5、测试验证

在这里插入图片描述

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

搞什么滚去学习

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值