LVS之高可用集群DR

2023-10-23 13:08
文章标签 集群 可用 dr lvs 之高

本文主要是介绍LVS之高可用集群DR,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

LVS之高可用集群DR

  • 一、LVS-DR工作原理
    • 1、数据包流向分析
    • 2、DR模式的特点
  • 二、LVS-DR中的ARP问题
    • 问题一:
    • 问题二:
  • 三、LVS负载均衡DR模式群集部署
    • 1、部署共享存储
    • 2、配置节点服务器
    • 3、配置负载调度器
    • 4、测试验证

一、LVS-DR工作原理

1、数据包流向分析

在这里插入图片描述

2、DR模式的特点

在这里插入图片描述

二、LVS-DR中的ARP问题

问题一:

在这里插入图片描述

问题二:

在这里插入图片描述

修改 /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

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

搭建环境:
DR 服务器(负载调度器)192.168.221.30 | ens33:0 (VIP):192.168.221.100
NFS服务器 CentOS7 192.168.221.20
Web节点服务器1 192.168.221.109 | lo:0 (VIP):192.168.221.100
Web节点服务器2 192.168.221.110 | lo:0 (VIP):192.168.221.100
客户端 Windows10 192.168.221.88

1、部署共享存储

NFS服务器:192.168.221.20systemctl stop firewalld.service
systemctl disable firewalld.service
setenforce 0yum -y install nfs-utils rpcbindsystemctl start rpcbind.service
systemctl start nfs.service
systemctl enable nfs.service
systemctl enable rpcbind.servicemkdir /opt/test1
mkdir /opt/test2chmod 777 /opt/test1
chmod 777 /opt/test2vim /etc/exports
/opt/test1 192.168.221.0/24(rw,sync)
/opt/test2 192.168.221.0/24(rw,sync)exportfs -rv

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

2、配置节点服务器

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

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

在这里插入图片描述
(1)web1和web2配置虚拟 IP 地址(VIP:192.168.221.100)

#此地址仅用做发送 Web 响应数据包的源地址,并不需要监听客户机的访问请求(改由调度器监听并分发)。
#因此使用虚接口 lo:0 来承载 VIP 地址,并为本机添加一条路有记录,将访问 VIP 的数据限制在本地,以避免通信紊乱。vim /etc/sysconfig/network-scripts/ifcfg-lo:0
DEVICE=lo:0
IPADDR=192.168.221.100
NETMASK=255.255.255.255
ONBOOT=yesifup lo:0
ifconfig lo:0#设置临时的路由,重启失效;禁锢路由
route add -host 192.168.221.100 dev lo:0
#查看路由
route -n#开机自动添加路由,生产环境应该用这个
vim /etc/rc.local
/sbin/route add -host 192.168.221.100 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 = 2sysctl -pyum 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.221.109 lo:0 (VIP):192.168.221.100
showmount -e 192.168.221.20
mount.nfs 192.168.221.20:/opt/test1 /var/www/html
echo 'this is test1 web!' > /var/www/html/index.htmlWeb节点服务器2:ens33:192.168.221.110 lo:0 (VIP):192.168.221.100(同web1差不多)
showmount -e 192.168.221.20
mount.nfs 192.168.221.20:/opt/test2 /var/www/html
echo 'this is test2 web!' > /var/www/html/index.html

在这里插入图片描述

3、配置负载调度器

负载调度器:192.168.221.30 lo:0 (VIP):192.168.221.100
(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.221.100)

vim /etc/sysconfig/network-scripts/ifcfg-ens33:0
DEVICE=ens33:0
ONBOOT=yes
IPADDR=192.168.221.100
NETMASK=255.255.255.255ifup 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 = 0sysctl -p

在这里插入图片描述
(4)配置负载分配策略

ipvsadm-save > /etc/sysconfig/ipvsadm
或者
ipvsadm --save > /etc/sysconfig/ipvsadmsystemctl start ipvsadm.service#清除原有策略
ipvsadm -C
ipvsadm -A -t 192.168.221.100:80 -s rr
ipvsadm -a -t 192.168.221.100:80 -r 192.168.221.109:80 -g #如果这里是隧道模式,直接将-g替换成-i即可
ipvsadm -a -t 192.168.221.100:80 -r 192.168.221.110:80 -g#查看节点状态,Route代表 DR模式
ipvsadm -ln

在这里插入图片描述

4、测试验证

在客户端访问 http://192.168.221.88/,刷新测试负载均衡是否成功
在这里插入图片描述

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

这篇关于LVS之高可用集群DR的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/268030

相关文章

Jenkins分布式集群配置方式

《Jenkins分布式集群配置方式》:本文主要介绍Jenkins分布式集群配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装jenkins2.配置集群总结Jenkins是一个开源项目,它提供了一个容易使用的持续集成系统,并且提供了大量的plugin满

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

SpringBoot连接Redis集群教程

《SpringBoot连接Redis集群教程》:本文主要介绍SpringBoot连接Redis集群教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 依赖2. 修改配置文件3. 创建RedisClusterConfig4. 测试总结1. 依赖 <de

Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例

《Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例》本文介绍Nginx+Keepalived实现Web集群高可用负载均衡的部署与测试,涵盖架构设计、环境配置、健康检查、... 目录前言一、架构设计二、环境准备三、案例部署配置 前端 Keepalived配置 前端 Nginx

Redis高可用-主从复制、哨兵模式与集群模式详解

《Redis高可用-主从复制、哨兵模式与集群模式详解》:本文主要介绍Redis高可用-主从复制、哨兵模式与集群模式的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录Redis高可用-主从复制、哨兵模式与集群模式概要一、主从复制(Master-Slave Repli

Redis分片集群的实现

《Redis分片集群的实现》Redis分片集群是一种将Redis数据库分散到多个节点上的方式,以提供更高的性能和可伸缩性,本文主要介绍了Redis分片集群的实现,具有一定的参考价值,感兴趣的可以了解一... 目录1. Redis Cluster的核心概念哈希槽(Hash Slots)主从复制与故障转移2.

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

centos7基于keepalived+nginx部署k8s1.26.0高可用集群

《centos7基于keepalived+nginx部署k8s1.26.0高可用集群》Kubernetes是一个开源的容器编排平台,用于自动化地部署、扩展和管理容器化应用程序,在生产环境中,为了确保集... 目录一、初始化(所有节点都执行)二、安装containerd(所有节点都执行)三、安装docker-

如何在一台服务器上使用docker运行kafka集群

《如何在一台服务器上使用docker运行kafka集群》文章详细介绍了如何在一台服务器上使用Docker运行Kafka集群,包括拉取镜像、创建网络、启动Kafka容器、检查运行状态、编写启动和关闭脚本... 目录1.拉取镜像2.创建集群之间通信的网络3.将zookeeper加入到网络中4.启动kafka集群

Nacos集群数据同步方式

《Nacos集群数据同步方式》文章主要介绍了Nacos集群中服务注册信息的同步机制,涉及到负责节点和非负责节点之间的数据同步过程,以及DistroProtocol协议在同步中的应用... 目录引言负责节点(发起同步)DistroProtocolDistroSyncChangeTask获取同步数据getDis