LVS负载均衡 DR模式

news/2024/7/9 23:40:41 标签: 服务器, 运维, 网络, 负载均衡, lvs

目录

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

1.配置负载调度器(192.168.110.100)

2.部署共享存储(NFS服务器:192.168.80.13)

3.配置节点服务器(192.168.80.100、192.168.80.101)

4.测试 LVS 群集


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

DR 服务器:192.168.110.100
Web 服务器1:192.168.110.70
Web 服务器2:192.168.110.60
vip:192.168.110.95
客户端:192.168.110.86

1.配置负载调度器(192.168.110.100)

systemctl stop firewalld.service
setenforce 0
modprobe ip_vs
cat /proc/net/ip_vs
yum -y install ipvsadm

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

cd /etc/sysconfig/network-scripts/
cp ifcfg-ens33 ifcfg-ens33:0                #若隧道模式,复制为ifcfg-tunl0
vim ifcfg-ens33:0
DEVICE=ens33:0
ONBOOT=yes
IPADDR=192.168.110.95
NETMASK=255.255.255.255
ifup ens33:0
ifconfig ens33:0


(2)调整 proc 响应参数
#由于 LVS 负载调度器和各节点需要共用 VIP 地址,需要关闭 icmp 的重定向,不充当路由器。

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

(3)配置负载分配策略

ipvsadm-save > /etc/sysconfig/ipvsadm
systemctl start ipvsadm
ipvsadm -C
ipvsadm -A -t 192.168.110.95:80 -s rr
ipvsadm -a -t 192.168.110.95:80 -r 192.168.110.70:80 -g            #若隧道模式,-g替换为-i
ipvsadm -a -t 192.168.110.95:80 -r 192.168.110.60:80 -g
ipvsadm
ipvsadm -ln                    #查看节点状态,Route代表 DR模式


2.部署共享存储(NFS服务器:192.168.80.13)

systemctl stop firewalld.service
setenforce 0
yum -y install nfs-utils rpcbind
mkdir /opt/kgc /opt/benet
chmod 777 /opt/kgc /opt/benet
vim /etc/exports
/usr/share *(ro,sync)
/opt/zxr  192.168.110.0/24(rw,sync)
/opt/yyds 192.168.110.0/24(rw,sync)
systemctl start rpcbind.service
systemctl start nfs.service

3.配置节点服务器(192.168.80.100、192.168.80.101)

systemctl stop firewalld.service
setenforce 0

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

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

cd /etc/sysconfig/network-scripts/
cp ifcfg-lo ifcfg-lo:0  
vim ifcfg-lo:0
DEVICE=lo:0
ONBOOT=yes
IPADDR=192.168.110.95
NETMASK=255.255.255.255                        #注意:子网掩码必须全为 1
ifup lo:0
ifconfig lo:0
route add -host 192.168.110.95 dev lo:0
vim /etc/rc.local
/sbin/route add -host 192.168.110.95 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

或者

echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce
echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce

sysctl -p
yum -y install nfs-utils rpcbind httpd
systemctl start rpcbind
systemctl start httpd

--192.168.110.60---

mount.nfs 192.168.110.90:/opt/kgc /var/www/html
echo '98765' > /var/www/html/index.html

--192.168.110.70---

mount.nfs 192.168.110.90:/opt/yyds /var/www/html
echo '123456' > /var/www/html/index.html

4.测试 LVS 群集

在客户端使用浏览器访问 http://192.168.80.188/

 

 


http://www.niftyadmin.cn/n/412139.html

相关文章

【Linux编程——时间处理:获取当前时间戳、转换本地时间和格式化时间】

本篇博客主要介绍 Linux 编程中常用的时间处理函数,包括获取当前时间、时间戳转换为本地时间、时间格式转换等等。 1. 获取当前时间 在 Linux 编程中,常常需要获取当前时间进行一些操作,例如计算程序的运行时间、记录日志等等。下面介绍两个…

3DCAT亮相糖酒会,为元宇宙展会提供实时云渲染支持

4月12日,第108届全国糖酒商品交易会(下文简称“糖酒会”)在成都正式开幕,吸引了众多酒类企业和行业人士的参与。 图片源自新华社 本次糖酒会上,某展会采用了“双线”模式,除了线下的实体展位,还…

代码随想录二刷 226 翻转二叉树 102 二叉树的层序遍历 101 对称二叉树

226 翻转二叉树 代码如下 func invertTree(root *TreeNode) *TreeNode { if root nil { 采用前序遍历,如果当前节点为空,就返回空 return nil } root.Left,root.Right root.Right, root.Left 交换该节点的…

Next 主题配置

当前用得最多的是next主题,那为什么用得多呢?当然是符合大多数人的审美。我使用的是next(v7.8.0),下载地址:theme-next/hexo-theme-next 1 基本设置 1.1 主题设置 打开博客根目录 Blog 文件夹,右键 Git Bash&#xf…

这些10款优秀的交互设计软件,你知道吗?

交互软件可以帮助设计师从“可用性”和“用户体验”的角度优化他们的作品。如果设计师想创建一个令人满意的交互设计作品,一个方便的交互设计软件是必不可少的。 根据设计师的个人喜好和方便,选择易于使用的交互设计软件来完成创建。本文盘点十款易于使…

1098 Insertion or Heap Sort (PAT甲级)

1098. Insertion or Heap Sort (25)-PAT甲级真题&#xff08;堆排序&#xff09;_柳婼的博客-CSDN博客 已经根据柳婼的解法改进了一些&#xff0c;但她的代码还是简洁不少。 #include <cstdio> #include <vector> #include <algorithm>int N, i; std::vect…

【Python基础】Python数据容器(元组)

文章目录 数据容器&#xff1a;tuple&#xff08;元组&#xff09;元组的定义格式元组的相关操作元组的相关操作-注意事项元组的特点 数据容器&#xff1a;tuple&#xff08;元组&#xff09; 元组的定义格式 元组定义&#xff1a;定义元组使用小括号&#xff0c;且使用逗号隔…

Java代码的运行过程

我们来聊一聊java代码是如何运行的。大家都知道java是运行在JVM上的&#xff0c;那它是怎么结合操作系统去控制那些硬件设备的呢&#xff1f; 其实想要知道这个问题我们可以跟踪一行代码的整个生命周期来解释&#xff0c;我把它抽象为这么五个步骤。 首先这行代码会被编译成字节…