【LVS】负载均衡群集部署(DR模式)

部署前IP分配

        DR服务器:192.168.166.101 vip:192.168.166.100

        Web服务器1:192.168.166.104 vip:192.168.166.100

        Web服务器2:192.168.166.107 vip:192.168.166.100

        NFS服务器:192.168.166.108

一、部署NFS服务器(192.168.166.108)

1、安装nfs

systemctl stop ufw
systemctl disable ufw
apt install -y nfs-kernel-server
systemctl status nfs-kernel-server

 2、准备两个共享目录

cd /opt
mkdir  xy1  xy2
vim /etc/exports添加以下配置:
/opt/xy1 *(rw,sync,no_subtree_check,no_root_squash)
/opt/xy2 192.168.166.0/24(rw,sync,no_subtree_check,no_root_squash)

3、向外发布

exportfs -arv

4、准备测试文件

 echo '<h1>this is xy1 test web</h1>' > xy1/test.htmlecho '<h1>this is xy2 test web</h1>' > xy2/test.html

二、Web服务器部署nfs

1、安装上传工具

systemctl stop ufw
systemctl disable ufw
apt install -y nfs-common
apt install lrzsz
上传nginx_1.24.0-1~jammy_amd64.deb
dpkg -i nginx_1.24.0-1~jammy_amd64.deb

        另一台服务器上做相同操作。 

2、修改配置文件

cd /etc/nginx/conf.dvim default.conf修改:location / {root   /usr/share/nginx/html;index  index.html index.htm;}为location / {root   /var/www/html;index  index.html index.htm;}

3、测试与nfs服务器连通性

mkdir -p /var/www/html
showmount -e 192.168.166.108

 4、挂载

        将nfs服务器的xy1挂载到ubuntu4的/var/www/html文件夹下

mount 192.168.166.108:/opt/xy1 /var/www/html

        将共享文件夹的目录下的文件复制过来

cp /usr/share/nginx/html/* ./

        在另一台虚拟机上进行同样操作到连通nfs服务器

        将xy2挂载到/var/www/html目录下

同样将共享文件夹的目录下的文件复制过来

cp /usr/share/nginx/html/* ./

5、创建一个新的网卡文件

cd /etc/netplan/touch 99-lo-vip.yamlvim 99-lo-vip.yaml network:ethernets:lo:addresses:- 192.168.166.100/32version: 2

netplan applyip a

6、给两台主机添加内核参数

vim /etc/sysctl.confnet.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 -p

        在另一台主机上进行相同操作

#启动nginxsystemctl start nginxsystemctl enable nginxdf -hT

确认是否已经将共享存储的目录挂载过来

 7、登陆网页测试

三、配置负载调度器

(ubuntu1:192.168.166.101)

1、加载 ip_vs 模块,安装ipvsadm工具

systemctl stop ufw
systemctl disable ufwmodprobe ip_vs
cat /proc/net/ip_vs

for i in $(ls /usr/lib/modules/$(uname -r)/kernel/net/netfilter/ipvs|grep -o "^[^.]*");do echo $i; /sbin/modinfo -F filename $i >/dev/null 2>&1 && /sbin/modprobe $i;done
lsmod | grep ip_vsapt update
apt -y install ipvsadm

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

#临时生效(重启失效)
ip addr add 192.168.166.100/24 dev ens33 label ens33:0#永久生效
vim /etc/netplan/XXX.yaml
network:version: 2 ethernets:ens33:addresses:​        192.168.80.10/24 
​		192.168.166.100/32  # 添加VIP netplan apply 

3、启用IP转发

#临时生效
sysctl -w net.ipv4.ip_forward=1#永久生效
echo "net.ipv4.ip_forward=1" | tee -a /etc/sysctl.conf或者vim /etc/sysctl.conf添加net.ipv4.ip_forward=1sysctl -p

 4、配置负载均衡规则

#添加虚拟服务
ipvsadm -A -t 192.168.166.100:80 -s wrr #添加真实服务器(-g表示DR模式)
ipvsadm -a -t 192.168.166.100:80 -r 192.168.166.104:80 -g -w 1
ipvsadm -a -t 192.168.166.100:80 -r 192.168.166.107:80 -g -w 1#查看规则 
ipvsadm -Ln 

重新打开一个主机用于测试(ubuntu3:192.168.166.103)

 5、验证ARP抑制

#在客户端上执行,应只能看到Director的MAC地址响应VIP
apt install -y arping
arping -I ens33 192.168.166.100

 6、安装Nginx

apt install -y nginx nfs-common

测试 LVS 群集

        在客户端使用浏览器访问 http://192.168.166.100/test.html

观察请求分发情况

ipvsadm -Ln --stats

7、测试实现负载均衡

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/73822.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++Primer学习(14.1 基本概念)

当运算符作用于类类型的运算对象时&#xff0c;可以通过运算符重载重新定义该运算符的含义。明智地使用运算符重载能令我们的程序更易于编写和阅读。举个例子&#xff0c;因为在Sales_item类中定义了输入、输出和加法运算符&#xff0c;所以可以通过下述形式输出两个Sales_item…

计算机视觉准备八股中

一边记录一边看&#xff0c;这段实习跑路之前运行完3DGAN&#xff0c;弄完润了&#xff0c;现在开始记忆八股 1.CLIP模型的主要创新点&#xff1a; 图像和文本两种不同模态数据之间的深度融合、对比学习、自监督学习 2.等效步长是每一步操作步长的乘积 3.卷积层计算输入输出…

基于大语言模型的智能音乐创作系统——从推荐到生成

一、引言&#xff1a;当AI成为音乐创作伙伴 2023年&#xff0c;一款由大语言模型&#xff08;LLM&#xff09;生成的钢琴曲《量子交响曲》在Spotify冲上热搜&#xff0c;引发音乐界震动。传统音乐创作需要数年专业训练&#xff0c;而现代AI技术正在打破这一壁垒。本文提出一种…

Mysql---锁篇

1&#xff1a;MySQL 有哪些锁&#xff1f; 全局锁 flush tables with read lock 整个数据库就处于只读状态了 unlock tables 释放全局锁 全局锁主要应用于做全库逻辑备份&#xff0c;这样在备份数据库期间&#xff0c;不会因为数据或表结构的更新&#xff0c;而出现备份文件的数…

VLAN综合实验二

一.实验拓扑&#xff1a; 二.实验需求&#xff1a; 1.内网Ip地址使用172.16.0.0/分配 2.sw1和SW2之间互为备份 3.VRRP/STP/VLAN/Eth-trunk均使用 4.所有Pc均通过DHCP获取IP地址 5.ISP只能配置IP地址 6.所有…

GEO(生成引擎优化)实施策略全解析:从用户意图到效果追踪

——基于行业实证的AI信源占位方法论 ​一、理解用户查询&#xff1a;构建AI语料的核心起点 生成式AI的内容推荐逻辑以用户意图为核心&#xff0c;​精准捕捉高频问题是GEO优化的第一步。企业需通过以下方法挖掘用户真实需求&#xff1a; ​AI对话日志分析&#xff1a; 分析用…

HTML基础及进阶

目录 一、HTML基础 1.什么是HTML 2.常用标签 &#xff08;1&#xff09;标题标签&#xff1a;h1-h6数字越小文字会越大&#xff0c;这个标签会占一整行 &#xff08;2&#xff09;加粗标签&#xff1a; &#xff08;3&#xff09;换行标签&#xff1a; &#xff08;4&am…

MSTP与链路聚合技术

MSTP&#xff08;多生成树协议&#xff09; 简介 MSTP&#xff08;多生成树协议&#xff09;是Spanning Tree Protocol&#xff08;STP&#xff09;的改进版&#xff0c;支持网络中使用多条生成树&#xff0c;并根据用户需求限制生成树间的路径。MSTP将多个VLAN映射到一棵生成…

ModuleNotFoundError: No module named ‘ml_logger.logbook‘

问题 (legion) zhouy24RL-DSlab:~/zhouy24Files/legion/LEGION$ python main.py ML_LOGGER_USER is not set. This is required for online usage. Traceback (most recent call last): File “main.py”, line 7, in from mtrl.app.run import run File “/data/zhouy24File…

c# ftp上传下载 帮助类

工作中FTP的上传和下载还是很常用的。如下载打标数据,上传打标结果等。 这个类常用方法都有了:上传,下载,判断文件夹是否存在,创建文件夹,获取当前目录下文件列表(不包括文件夹) ,获取当前目录下文件列表(不包括文件夹) ,获取FTP文件列表(包括文件夹), 获取当前目…

PyTorch 分布式训练(Distributed Data Parallel, DDP)简介

PyTorch 分布式训练&#xff08;Distributed Data Parallel, DDP&#xff09; 一、DDP 核心概念 torch.nn.parallel.DistributedDataParallel 1. DDP 是什么&#xff1f; Distributed Data Parallel (DDP) 是 PyTorch 提供的分布式训练接口&#xff0c;DistributedDataPara…

策略模式_行为型_GOF23

策略模式 策略模式&#xff08;Strategy Pattern&#xff09;是一种行为型设计模式&#xff0c;核心思想是将一组算法封装成独立对象&#xff0c;使它们可以相互替换&#xff0c;从而让算法的变化独立于使用它的客户端。这类似于游戏中的技能切换——玩家根据战况选择不同技能…

【Python】天气数据可视化

1. Python进行数据可视化 在数据分析和科学计算领域&#xff0c;Python凭借其强大的库和简洁的语法&#xff0c;成为了众多开发者和科研人员的首选工具。数据可视化作为数据分析的重要环节&#xff0c;能够帮助我们更直观地理解数据背后的规律和趋势。本文将详细介绍如何使用P…

深度学习4.4笔记

《动手学深度学习》-4.4-笔记 验证数据集&#xff1a;通常是从训练集中划分出来的一部分数据&#xff0c;不要和训练数据混在一起&#xff0c;评估模型好坏的数据集 测试数据集&#xff1a;只用一次的数据集 k-折交叉验证&#xff08;k-Fold Cross-Validation&#xff09;是…

vue 两种路由模式

一、两种模式比较 在vue.js中&#xff0c;路由模式分为两种&#xff1a;hash 模式和 history 模式。这两种模式决定了URL的结构和浏览器历史记录的管理方式。 1. hash 模式带 #&#xff0c;#后面的地址变化不会引起页面的刷新。换句话说&#xff0c;hash模式不会将#后面的地址…

Android生态大变革,谷歌调整开源政策,核心开发不再公开

“开源”这个词曾经是Android的护城河&#xff0c;如今却成了谷歌的烫手山芋。最近谷歌宣布调整Android的开源政策&#xff0c;核心开发将全面转向私有分支。翻译成人话就是&#xff1a;以后Android的核心更新&#xff0c;不再公开共享了。 这操作不就是开源变节吗&#xff0c;…

JavaScript中集合常用操作方法详解

JavaScript中集合常用操作方法详解 JavaScript中的集合主要包括数组(Array)、集合(Set)和映射(Map)。下面我将详细介绍这些集合类型的常用操作方法。 数组(Array) 数组是JavaScript中最常用的集合类型&#xff0c;提供了丰富的操作方法。 创建数组 // 字面量创建 const ar…

【HC-05】蓝牙串口通信模块调试与应用(1)

一、HC-05 基础学习视频 HC-05蓝牙串口通信模块调试与应用1 二、HC-05学习视频课件

【学Rust写CAD】18 定点数2D仿射变换矩阵结构体(MatrixFixedPoint结构别名)

源码 // matrix/fixed.rs use crate::fixed::Fixed; use super::generic::Matrix;/// 定点数矩阵类型别名 pub type MatrixFixedPoint Matrix<Fixed, Fixed, Fixed, Fixed, Fixed, Fixed>;代码解析 这段代码定义了一个定点数矩阵的类型别名 MatrixFixedPoint&#xff…

axios文件下载使用后端传递的名称

java后端通过HttpServletResponse 返回文件流 在Content-Disposition中插入文件名 一定要设置Access-Control-Expose-Headers&#xff0c;代表跨域该Content-Disposition返回Header可读&#xff0c;如果没有&#xff0c;前端是取不到Content-Disposition的&#xff0c;可以在统…