欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 健康 > 养生 > LVS中的DR模式,直接路由模式

LVS中的DR模式,直接路由模式

2025/5/8 19:31:37 来源:https://blog.csdn.net/ZHX2285/article/details/147756712  浏览:    关键词:LVS中的DR模式,直接路由模式

DR模式工作原理介绍

请求经过调度器,响应由real  server  直接响应给客户端。

如上图所示,real server想要正常访问互联网,后端的real server的网关就得写网络中真实的网关。

DR模式的核心要素:【重点】

1.请求经过调度器,响应由real server直接给客户端

2.配置real  server网关时要写网络中真实的网关,确保real  server可以正常访问互联网。

3.DIP,VIP要在相同的网络中。

4.在所有的real  server上配置vip,目的就是为了让real server能够正常的处理客户端请求。

arp_ignore=1 只让主机回复关于物理网卡的ARP响应。

arp_announce=2让主机以适当的地址发送响应。

5.real  server的操作系统只能是类Linux操作系统,【原因是系统的参数可以修改。】

不会涉及到地址的转换。

在LVS的DR模式当中,调度器的DIP和VIP地址,和后端服务器的RIP地址都处于一个网段中,

当客户端请求转发到后端服务器的时候,后端服务器对客户端请求进行数据处理,对客户端请求进行解封装的时候,会发现这个请求是发送给调度器的VIP地址的。

任何一个主机收到一份数据只要这个目的地址不是主机IP,那么这个主机就会丢弃这份数据,给客户端带来的影响就是客户端访问不到服务。

如上图所示,怎么解决这个问题?

因此,以LVS的DR模式构建集群的时候,为了确保后端的real  server能够正常的处理请求。

我们需要在DR模式里面,在每个real server机器上也都去配置vip地址。

但是此时同一个IP地址,也就是说同一个VIP地址出现在多台机器上,这会造成IP地址冲突的问题,

此时我们还需要去解决IP地址冲突的问题,

那么我们想一下,主机和主机之间是怎么检测到IP地址有冲突的?

使用的就是ARP协议

ARP协议的作用就是用来获取某个IP地址对应的MAC地址的。

如果主机向外界发送IP地址为192.168.88.10的IP地址,并且询问这个IP地址对应的MAC地址,如果主机收到了这个IP对应的MAC地址则证明IP地址冲突,如果主机没有收到关于这个IP地址对应的MAC地址则证明IP地址没有冲突。【这个主机的IP地址是192.168.88.10】

在LVS的DR模式的负载均衡集群中,我们可以想办法使得real server机器上的VIP地址不往外发送关于ARP协议的响应,只让调度器上的VIP地址往外发送关于ARP协议的响应。【此时就解决了vip地址冲突的问题。】

如上图所示,我们可以去手动修改real  server上内核参数,即使得net.ipv4.conf.all.arp_ignore=1

arp_ignore的取值有0和1和2

其中0表示允许机器响应关于arp协议的请求,2表示禁止机器响应所有关于arp协议的请求。

1表示的是只让机器回复关于物理网卡IP地址的ARP响应。

使得real  server不响应虚拟网卡的ARP协议响应。

real  server上有两个IP地址,一个是物理网卡上的IP地址,一个是虚拟网卡上的IP地址,那么此时real  server再往外发送数据的时候,默认的源IP地址都会是物理网卡的IP地址。此时客户端面对响应数据的源IP地址是real  server物理网卡的IP地址的时候,就会把响应数据丢弃。

造成的结果还是客户端无法访问服务。

此时我们面对这个问题,我们还需要修改real  server机器上的另一个内核参数,

arp_announce=0修改默认值为2

此时的real  server再次往外发送数据的时候,就会以合适的IP地址向外发送数据。【也就是说,如果访问的是real server上的VIP地址,real server就以虚拟网卡的VIP地址进行回应,如果访问的是real  server上的物理网卡的IP地址,real server就会以物理网卡的IP地址进行回应。】

DR模式web集群案例

如上图所示,做一个DR模式的web集群案例。、

1)real  server安装httpd,建立测试文件。

2)在所有的real  server上配置VIP【配置在本地回环网卡上,】

在DR模式里面配置VIP的时候,VIP的子网掩码必须是32位子网掩码,子网掩码全部都是1

此时的VIP即是一个网段,也是一个IP,这个网段中的IP地址只有VIP自己,不能写其他的子网掩码,否则这个VIP地址中会多出来到达这个VIP地址的路由地址,会影响我们服务的正常访问。

如上图所示,这就是添加IP地址到指定网卡的操作。

如上图所示,每个real  server的机器上都要配置这个VIP地址。

这条命令是临时生效的,如果想要这个命令永久生效,就需要将这个命令写到rc.local文件里面。

3.修改所有real  server上的arp参数。

如上图所示,我们需要在real  server机器上将net.ipv4.conf.all.arp_ignore=0修改为1

如上图所示,我们需要设置这个net.ipv4.conf.all.arp_announce=2

随后使用systctl  -p使得修改的内核参数生效。

4)在调度器上配置VIP地址。

如上图所示,将VIP地址添加到调度器上的lo本地回环网卡上,

5)创建虚拟服务

如上图所示,这是在调度器上创建虚拟服务,配置负载均衡集群,查看负载均衡表的操作。

6)测试访问

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词