当前位置: 首页 > news >正文

LVS搭建负载均衡

LVS搭建负载均衡

引言

在现代互联网应用中,用户对服务的可用性和响应速度要求越来越高。为了应对高并发请求,保证系统的稳定性和容错能力,负载均衡技术应运而生。LVS(Linux Virtual Server)是一种高性能、高可用性的负载均衡解决方案,能够将多个后端服务器聚合成一个虚拟服务器,以提高服务的可用性和扩展性。本文将详细介绍LVS的搭建过程,包括环境准备、配置步骤、监控与维护等方面。

一、LVS的基本概念

1.1 什么是LVS?

LVS是Linux内核的一部分,它提供了一种通过IP负载均衡的方式,将用户请求分发到多台后端服务器。LVS可以实现高效的负载均衡和高可用性,适用于大规模网站和应用。

1.2 LVS的工作原理

LVS主要有三种工作模式:

  • NAT模式(Network Address Translation):在这种模式下,LVS将请求转发给后端服务器,然后将响应再转发给客户端。适合于后端服务器和客户端在同一网络中时。

  • DR模式(Direct Routing):在这种模式下,LVS将请求直接送到后端服务器,响应也直接返回给客户端,减少了负载均衡器的负担,提高了性能。

  • TUN模式(Tunneling):通过隧道技术,将负载均衡器与后端服务器分开。

1.3 LVS的优势

  • 高可用性:通过负载均衡,系统不会因为单点故障而导致服务中断。
  • 可扩展性:可以根据需求动态添加或移除后端服务器。
  • 灵活性:支持多种负载均衡算法,如轮询、最少连接、加权轮询等。

二、环境准备

在开始搭建LVS之前,需要准备以下环境:

2.1 服务器准备

  • 一台LVS负载均衡器(假设IP为192.168.1.100)。
  • 多台后端真实服务器(假设IP为192.168.1.101192.168.1.102)。
  • 确保所有服务器之间的网络连接畅通。

2.2 安装依赖

在LVS负载均衡器上,需要安装ipvsadm工具。可以使用以下命令在CentOS上安装:

sudo yum install ipvsadm -y

三、LVS的基本配置

3.1 启动IPVS服务

首先,启动IPVS服务:

sudo ipvsadm -A -t 192.168.1.200:80 -s rr

上述命令中,192.168.1.200是我们将用于负载均衡的虚拟IP(VIP),80是监听的端口,-s rr表示使用轮询算法。

3.2 添加真实服务器

接下来,添加后端真实服务器:

sudo ipvsadm -a -t 192.168.1.200:80 -r 192.168.1.101:80 -g
sudo ipvsadm -a -t 192.168.1.200:80 -r 192.168.1.102:80 -g

这里,-g表示使用直接路由模式。

3.3 查看配置

使用以下命令查看当前的LVS配置:

sudo ipvsadm -L -n

你应该能看到类似于以下的输出:

IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags-> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.1.200:80 rr-> 192.168.1.101:80             Route   1      0          0-> 192.168.1.102:80             Route   1      0          0

3.4 配置后端服务器

确保后端服务器(192.168.1.101192.168.1.102)上安装了Web服务(如Apache或Nginx),并确保相应服务正常运行。可以创建一个简单的HTML页面来确认服务器是否能够正常响应请求。

<!-- /var/www/html/index.html -->
<!DOCTYPE html>
<html>
<head><title>Hello from Server</title>
</head>
<body><h1>Hello from Server 1</h1>
</body>
</html>

四、健康检查与监控

为了确保LVS能够将流量分发到健康的后端服务器,需要实现健康检查。可以使用keepalived来实现这一功能。

4.1 安装Keepalived

在LVS负载均衡器上安装keepalived

sudo yum install keepalived -y

4.2 配置Keepalived

编辑/etc/keepalived/keepalived.conf文件,设置虚拟IP和健康检查。以下是一个基本的配置示例:

vrrp_instance VI_1 {state MASTERinterface eth0virtual_router_id 51priority 100advert_int 1authentication {auth_type PASSauth_pass 1234}virtual_ipaddress {192.168.1.200  # VIP}
}virtual_server 192.168.1.200 80 {delay_loop 6lb_algo wrr  # 使用加权轮询算法lb_kind NATprotocol TCPreal_server 192.168.1.101 80 {weight 3HTTP_GET {url {path /health_check}timeout 3fall 2rise 2}}real_server 192.168.1.102 80 {weight 2HTTP_GET {url {path /health_check}timeout 3fall 2rise 2}}
}

4.3 启动Keepalived

启动Keepalived服务:

sudo systemctl start keepalived
sudo systemctl enable keepalived

五、LVS的负载均衡算法

LVS支持多种负载均衡算法,包括:

5.1 轮询(Round Robin)

默认的负载均衡算法,适用于请求处理时间相近的场景。通过ipvsadm命令设置:

sudo ipvsadm -A -t 192.168.1.200:80 -s rr

5.2 最少连接(Least Connection)

将请求分发到当前连接数最少的服务器,适合处理时间长的请求。通过ipvsadm命令设置:

sudo ipvsadm -A -t 192.168.1.200:80 -s lc

5.3 加权轮询(Weighted Round Robin)

根据服务器的权重进行负载均衡,权重越高的服务器接收的请求越多。通过ipvsadm命令设置:

sudo ipvsadm -A -t 192.168.1.200:80 -s wrr

5.4 IP哈希(IP Hash)

根据客户端的IP地址进行负载均衡,确保来自同一IP的请求总是被路由到同一台服务器。通过ipvsadm命令设置:

sudo ipvsadm -A -t 192.168.1.200:80 -s sh

六、监控与维护

6.1 使用监控工具

可以使用监控工具(如Zabbix、Prometheus等)监控LVS的性能指标,及时发现并解决问题。监控内容包括:

  • 负载均衡器的CPU和内存使用情况。
  • 后端服务器的健康状态和连接数。

6.2 定期检查

定期检查LVS的配置和运行状态,确保其正常运行。可以使用以下命令:

sudo ipvsadm -L -n

6.3 性能调优

根据实际流量情况,适时调整后端服务器的权重,以实现更好的负载均衡。

6.4 安全性考虑

在生产环境中,需要考虑安全性,防止未授权访问。可以使用iptables等工具限制访问。

七、故障处理与常见问题

7.1 服务器故障

当某台服务器出现故障时,可以通过以下命令查看LVS状态:

sudo ipvsadm -L -n

确保能够看到健康的真实服务器。

7.2 配置错误

如果LVS无法正常工作,检查配置文件是否存在错误。查看LVS的日志信息:

sudo tail -f /var/log/messages

7.3 网络问题

检查网络连接,确保LVS能够访问后端服务器:

ping 192.168.1.101

八、总结

LVS作为一种高效的负载均衡解决方案,能够有效提升系统的可用性和扩展性。通过合理的配置和优化,可以充分发挥LVS的优势,满足不同场景的需求。在搭建LVS的过程中,注意网络的配置、负载均衡算法的选择及后端服务器的健康监控,确保系统的稳定运行。

相关文章:

LVS搭建负载均衡

LVS搭建负载均衡 引言 在现代互联网应用中&#xff0c;用户对服务的可用性和响应速度要求越来越高。为了应对高并发请求&#xff0c;保证系统的稳定性和容错能力&#xff0c;负载均衡技术应运而生。LVS&#xff08;Linux Virtual Server&#xff09;是一种高性能、高可用性的…...

Unity MVC框架演示 1-1 理论分析

本文仅作学习笔记分享与交流&#xff0c;不做任何商业用途&#xff0c;该课程资源来源于唐老狮 1.一般的图解MVC 什么是MVC我就不说了&#xff0c;老生常谈&#xff0c;网上有大量的介绍&#xff0c;想看看这三层都起到什么职责&#xff1f;那就直接上图吧 2.我举一个栗子 我有…...

基于springboot+vue人脸识别的考勤管理系统(源码+定制+开发)

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…...

【api连接ChatGPT的最简单方式】

通过api连接ChatGPT的最简单方式 建立client 其中base_url为代理&#xff0c;若连接官网可省略&#xff1b;配置环境变量 from openai import OpenAI client OpenAI(base_url"https://api.chatanywhere.tech/v1" )或给出api和base_url client OpenAI(api_key&…...

技术成神之路:设计模式(二十)装饰模式

介绍 装饰模式&#xff08;Decorator Pattern&#xff09;是一种结构型设计模式&#xff0c;它允许在不改变对象自身的情况下&#xff0c;动态地为对象添加额外的职责。这个模式通常用于增强或改变对象的功能。 1.定义 装饰模式通过创建一个装饰类&#xff0c;将功能动态地添加…...

利用特征点采样一致性改进icp算法点云配准方法

1、index、vector 2、kdtree和kdtreeflann 3、if kdtree.radiusSearch(。。。) > 0)...

LabVIEW惯性导航系统仿真平台

LabVIEW开发捷联惯性导航系统仿真平台&#xff0c;采用模块化设计&#xff0c;利用LabVIEW的图形化编程特性&#xff0c;提高了系统仿真的效率和精度&#xff0c;同时具备良好的可扩展性和用户交互性。 项目背景 当前&#xff0c;惯性导航系统&#xff08;INS&#xff09;的研…...

es简单实现文章检索功能

使用的api是&#xff1a;Elasticsearch Java API client 8.0 官网&#xff1a;Package structure and namespace clients | Elasticsearch Java API Client [8.15] | Elastic 1.建立索引库 实现搜索功能字段&#xff1a; title&#xff1a;文章标题content&#xff1a;文章内…...

太速科技-607-基于FMC的12收和12发的光纤子卡

基于FMC的12收和12发的光纤子卡 一、板卡概述 本卡是一个FPGA夹层卡&#xff08;FMC&#xff09;模块&#xff0c;可提供高达2个CXP模块接口&#xff0c;提供12路收&#xff0c;12路发的光纤通道。每个通道支持10Gbps,通过Aurora协议&#xff0c;可以组成X4&#xff0…...

UEFI学习笔记(十):系统表与ACPI表的遍历

一、概述 在 UEFI 系统表中&#xff0c;有几个关键的表用于提供系统信息、服务和硬件抽象。这些表可以通过 EFI_SYSTEM_TABLE 访问&#xff0c;常见的 UEFI 系统表如下&#xff1a; 1、EFI_SYSTEM_TABLE (系统表) EFI_SYSTEM_TABLE 是一个指针&#xff0c;包含多个服务和系统…...

【深度学习基础模型】液态状态机(Liquid State Machines, LSM)详细理解并附实现代码。

【深度学习基础模型】液态状态机&#xff08;Liquid State Machines, LSM&#xff09;详细理解并附实现代码。 【深度学习基础模型】液态状态机&#xff08;Liquid State Machines, LSM&#xff09;详细理解并附实现代码。 文章目录 【深度学习基础模型】液态状态机&#xff0…...

深入理解链表(SList)操作

目录&#xff1a; 一、 链表介绍1.1、 为什么引入链表1.2、 链表的概念及结构1.3、 链表的分类 二、 无头单向非[循环链表](https://so.csdn.net/so/search?q循环链表&spm1001.2101.3001.7020)的实现2.1、 [单链表](https://so.csdn.net/so/search?q单链表&spm1001.2…...

03. prometheus 监控 Linux 主机

文章目录 一、prometheus 监控 Linux 主机二、防火墙打开端口1. 方式一&#xff1a;使用 iptables 添加白名单&#xff08;推荐使用&#xff09;&#xff1a;2. 方式二&#xff1a;重载防火墙 一、prometheus 监控 Linux 主机 1. 官网下载 node_exporter 官网&#xff1a;htt…...

AI占据2024诺贝尔两大奖项,是否预示着未来AI即一切?

本次诺贝尔物理学和学奖的获得者都与AI息息相关&#xff0c;可谓是“AI领域的大丰收”。 2024年诺贝尔物理学奖揭晓&#xff1a;瑞典皇家科学院公布了2024年诺贝尔物理学奖的获得者。他们是美国的约翰霍普菲尔德&#xff08;John J. Hopfield&#xff09;&#xff0c;以及加拿…...

[已解决] Install PyTorch 报错 —— OpenOccupancy 配环境

目录 关于 常见的初始化报错 环境推荐 torch, torchvision & torchaudio cudatoolkit 本地pip安装方法 关于 OpenOccupancy: 语义占用感知对于自动驾驶至关重要&#xff0c;因为自动驾驶汽车需要对3D城市结构进行细粒度感知。然而&#xff0c;现有的相关基准在城市场…...

6. PH47 代码框架硬件开发环境搭建

概述 PH47代码框架的硬件开发环境搭建同样简单&#xff0c; 建立基本的 PH47 框架学习或二次开发的硬件开发环境所需设备如下&#xff1a; BBP 飞控板及相关软硬件: BBP飞控板&#xff0c;或者至少一块Stm32F411核心板&#xff08;WeAct Studio&#xff09;Stm32程序烧录工具…...

package.json配置

package.json配置 描述配置文件配置脚本配置依赖配置发布配置系统配置第三方配置 描述配置 name : 项目名称&#xff0c;第三方包可以通过npm install 包名安装 "name":"react"version : 项目版本&#xff0c;项目版本号 "version" : "18.2…...

视频怎么转gif动图?5个简单转换方法快来学(详细教程)

相信大家在社交平台上会经常看到一些有趣的gif动图表情包&#xff0c;有些小伙伴就会问&#xff1a;这些GIF动图是如何制作的呢&#xff1f;一般GIF动图表情包可以用视频来制作&#xff0c;今天小编就来给大家分享几个视频转成GIF动图的方法&#xff0c;相信通过以下的几个方法…...

10月更新:优维EasyOps®需求解决更彻底,功能体验再升级

升 级 不 止 步 欢迎来到 需求至上&#xff0c;功能完善 的 \ EasyOps 7.5版本 / &#x1f447; >> 联动架构视图&#xff1a;深度融合监控与资源拓扑 传统上&#xff0c;依赖监控态势感知系统固有的分层拓扑结构虽有其优势&#xff0c;但在处理复杂系统尤其是核心数…...

黑马javaWeb笔记重点备份1:三层架构、IOC、DI

来自&#xff1a;【黑马程序员JavaWeb开发教程&#xff0c;实现javaweb企业开发全流程&#xff08;涵盖SpringMyBatisSpringMVCSpringBoot等&#xff09;】 https://www.bilibili.com/video/BV1m84y1w7Tb/?p75&share_sourcecopy_web&vd_source9332b8fc5ea8d349a54c398…...

Spring Boot 实现流式响应(兼容 2.7.x)

在实际开发中&#xff0c;我们可能会遇到一些流式数据处理的场景&#xff0c;比如接收来自上游接口的 Server-Sent Events&#xff08;SSE&#xff09; 或 流式 JSON 内容&#xff0c;并将其原样中转给前端页面或客户端。这种情况下&#xff0c;传统的 RestTemplate 缓存机制会…...

Objective-C常用命名规范总结

【OC】常用命名规范总结 文章目录 【OC】常用命名规范总结1.类名&#xff08;Class Name)2.协议名&#xff08;Protocol Name)3.方法名&#xff08;Method Name)4.属性名&#xff08;Property Name&#xff09;5.局部变量/实例变量&#xff08;Local / Instance Variables&…...

基于当前项目通过npm包形式暴露公共组件

1.package.sjon文件配置 其中xh-flowable就是暴露出去的npm包名 2.创建tpyes文件夹&#xff0c;并新增内容 3.创建package文件夹...

Python爬虫(二):爬虫完整流程

爬虫完整流程详解&#xff08;7大核心步骤实战技巧&#xff09; 一、爬虫完整工作流程 以下是爬虫开发的完整流程&#xff0c;我将结合具体技术点和实战经验展开说明&#xff1a; 1. 目标分析与前期准备 网站技术分析&#xff1a; 使用浏览器开发者工具&#xff08;F12&…...

TRS收益互换:跨境资本流动的金融创新工具与系统化解决方案

一、TRS收益互换的本质与业务逻辑 &#xff08;一&#xff09;概念解析 TRS&#xff08;Total Return Swap&#xff09;收益互换是一种金融衍生工具&#xff0c;指交易双方约定在未来一定期限内&#xff0c;基于特定资产或指数的表现进行现金流交换的协议。其核心特征包括&am…...

ip子接口配置及删除

配置永久生效的子接口&#xff0c;2个IP 都可以登录你这一台服务器。重启不失效。 永久的 [应用] vi /etc/sysconfig/network-scripts/ifcfg-eth0修改文件内内容 TYPE"Ethernet" BOOTPROTO"none" NAME"eth0" DEVICE"eth0" ONBOOT&q…...

给网站添加live2d看板娘

给网站添加live2d看板娘 参考文献&#xff1a; stevenjoezhang/live2d-widget: 把萌萌哒的看板娘抱回家 (ノ≧∇≦)ノ | Live2D widget for web platformEikanya/Live2d-model: Live2d model collectionzenghongtu/live2d-model-assets 前言 网站环境如下&#xff0c;文章也主…...

在树莓派上添加音频输入设备的几种方法

在树莓派上添加音频输入设备可以通过以下步骤完成&#xff0c;具体方法取决于设备类型&#xff08;如USB麦克风、3.5mm接口麦克风或HDMI音频输入&#xff09;。以下是详细指南&#xff1a; 1. 连接音频输入设备 USB麦克风/声卡&#xff1a;直接插入树莓派的USB接口。3.5mm麦克…...

深入浅出Diffusion模型:从原理到实践的全方位教程

I. 引言&#xff1a;生成式AI的黎明 – Diffusion模型是什么&#xff1f; 近年来&#xff0c;生成式人工智能&#xff08;Generative AI&#xff09;领域取得了爆炸性的进展&#xff0c;模型能够根据简单的文本提示创作出逼真的图像、连贯的文本&#xff0c;乃至更多令人惊叹的…...

mac:大模型系列测试

0 MAC 前几天经过学生优惠以及国补17K入手了mac studio,然后这两天亲自测试其模型行运用能力如何&#xff0c;是否支持微调、推理速度等能力。下面进入正文。 1 mac 与 unsloth 按照下面的进行安装以及测试&#xff0c;是可以跑通文章里面的代码。训练速度也是很快的。 注意…...