LSV负载均衡

什么是访问压力? -- 负载

两个客户同时访问一个服务器,会导致服务器崩溃
调度 ---Cluster 集群(为了解决一个特定问题,多台服务器组合使用形成的一个系统)

LSV

1、集群 Cluster

LB:负载均衡,有多个主机组成,每个主机只承担一部分访问
HA:高可用SPOF
HPC:高性能计算
每一台主机的实现的功能没有差别,数据和代码都一样;
不会因为一台主机挂了,其他都挂了

2、分布式

有一个人计算变成四个人计算;
一个业务被拆分成多个子业务,功能有差别,代码和数据也不一样;
分布式每个节点都 很重要,如果一个节点跨了,这个业务可能就会失败。
LSV 运行原理(目前的负载只是 3 层的)
LSV目前 只能到端口阶段
调度器究竟把流量给哪个REALSERVER的这个过程才叫做算法

  • VS:调度器
  • RS:真正的主机
  • CIP:客户端的IP
  • VIP:调度器连接外网的IP
  • DIP:调度器连接真正主机的IP
  • RIP:真正的主机的IP

LSV的操作流程(自我理解):客户端发起流量请求,(通过外网)申请首先到达LVS,调度器则调度到合适的realserver(通过内网),然后流量再通过原路返回至LVS,最后返回到客户机

后端建议最多挂10台,否则调度器受不了


LSV实训

环境:1个客户端,1个调度器,2个主机

client:172.25.254.111

LSV: 需要两个网卡,在设置里新增网卡,选择仅主机模式

分别配置两个IP地址,一个是VIP(172.25.254.100),一个是DIP(192.168.254.100)

RS1&RS2

也要在设置中选择仅主机模式,作为内网的RealServer1&2

运行脚本,配置IP地址

RS1:192.168.254.10 RS2:192.168.254.20


操作:

1、检测LVS是否能访问RS1&2

RS1&2下载httpd

关闭防火墙

确保能够访问上,RS1&2的任务就完成了

2、 IPVSADM

dnf install ipvsadm -y

集群服务管理

集群服务的RS管理

可以通过help来查看相关命令

简单解释

-D是删除一条部署

-d删除的则是后端的realserver

-E是修改

-a是增加后端的realserver

-C则是清空所有
-p 360 调度时间,在时间内就始终访问这个主机,时间过期了就重新调度一台主机

ipvsadm这个命令语句可以理解为加一个对外开放的业务

这里80是端口,-s则是调度的作用,-t是指TCP

watch -n1 ipvsadm -Ln可以实时检测到部署的变化(增删查改)

ipvsadm -A -f 66 -s rr火墙标记可以起到一个标识作用,流量可以找到原先的位置(之后还会详细讲解)

之前的命令行中-s之前的IP地址都是lvs的VIP

之后的IP地址则是,调度器想要流量流向的realserver

举例:ipvsadm -a -t 172.25.254.100:80 -r 192.168.254.10:80 -m


ipvsadm的备份与恢复

备份到其中,即使策略被完全清洗,也可以通过备份找齐

ipvsadm这个策略并不是永久存在的,此时开启服务是会报错的,因为此时没有本地的策略存在

设置本地的策略存放地

此时已经让服务能够开机时加载策略,永久保存

相关推荐
chlk12313 小时前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑13 小时前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件14 小时前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
碳基沙盒14 小时前
OpenClaw 多 Agent 配置实战指南
运维
深紫色的三北六号1 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash1 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI2 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行2 天前
Linux和window共享文件夹
linux
Sinclair2 天前
简单几步,安卓手机秒变服务器,安装 CMS 程序
android·服务器
木心月转码ing3 天前
WSL+Cpp开发环境配置
linux