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

【高可用架构】Haproxy 和 Keepalived 的区别

Haproxy 和 Keepalived 的区别

  • 1.负载均衡器介绍
  • 2.Haproxy 和 Keepalived 的基本概念和特点
    • 2.1 Haproxy
    • 2.2 Keepalived
  • 3.Haproxy 和 Keepalived 的区别
    • 3.1 功能上的区别
    • 3.2 架构上的区别
    • 3.3 配置上的区别
  • 4.总结

1.负载均衡器介绍

负载均衡器是一种解决高并发和高可用的常用的网络设备,它可以将流量分摊到多台服务器上,实现负载均衡,提高业务处理效率和稳定性。在负载均衡器的选择上,HaproxyKeepalived 是两个常用的开源负载均衡器。

2.Haproxy 和 Keepalived 的基本概念和特点

2.1 Haproxy

Haproxy 是一种高性能、轻量级、可靠的负载均衡器软件,主要用于在多台服务器上平衡 HTTP、HTTPS、TCP 和 UDP 协议的负载。它具有配置灵活、轻量级、占用资源少、支持远多于其他负载均衡软件的并发连接数等特点。Haproxy 完全可以负载大量的请求,并提供负载均衡处理与优秀的 Fail-over 机制。

Haproxy 的优点:

  • ✅ 可以轻松地管理连接,以减少服务器上的并发连接数。
  • ✅ 支持对服务器集群进行轻松的负载平衡。
  • ✅ 适用于低负载的环境,可以在不同的连接上提供很好的性能。
  • ✅ 支持不同的负载均衡算法,比如简单 Round Robin,Least Connection(连接数最少)等。

示例代码:

global# Log Settingslog /dev/log local0log /dev/log local1 notice# Daemon Settingsdaemon# Max Connection Limits Settingsmaxconn 2048# Defaults Configure
defaultslog globalmode httpoption httplogoption dontlognullretries 3option redispatchtimeout connect 5000timeout client 50000timeout server 50000# Frontend Settings 
frontend mainbind *:80default_backend nodes# The Backend
backend nodesbalance roundrobinserver web1 192.168.0.1:80 checkserver web2 192.168.0.2:80 check

2.2 Keepalived

Keepalived 是一个开源实现高可用性(HA)框架的软件,可以在多个服务器上实现负载均衡。与 Haproxy 不同的是,Keepalived 并不是负载均衡器本身,它可以提供实现 VRRP 协议的 IP 负载均衡器,可以检测负载均衡器的状态,从而负责将客户端请求转向主负载均衡器或备用负载均衡器。

Keepalived 的优点:

  • ✅ 可以保证集群的高可用性。
  • ✅ 支持状态检查以及能够转移到备份负载均衡器。
  • ✅ 具有高速自动故障切换的功能。
  • ✅ 可以检测主服务器的可用性,能够自动切换到备份服务器。

示例代码:

# Define Fix
vrrp_instance VI_1{state MASTER                                        # 主机状态interface bond0.101                                # 虚拟IP归属的网卡名称virtual_router_id 51                               # 虚拟IP的ID标示,保证唯一priority 100                                       # priority 值高的为 MASTER,自动 failback 是高优先级的advert_int 1                                       # 广播间隔时间virtual_ipaddress {192.168.101.15                           # 需要共享的虚拟IP}track_script {chk_haproxy                                       # 实时检测Haproxy进程是否存在}notify_master "/etc/keepalived/notify.sh master"  # MASTER节点切换前需要预先执行的命令notify_backup "/etc/keepalived/notify.sh backup"  # BACKUP节点切换前需要预先执行的命令notify_fault "/etc/keepalived/notify.sh fault"       # 节点切换完成后需要执行的命令
}

3.Haproxy 和 Keepalived 的区别

3.1 功能上的区别

Haproxy 属于应用层负载均衡器,可以支持 HTTP、HTTPS、TCP 和 UDP 协议的负载。而 Keepalived 是一个实现高可用性的软件,可以检测负载均衡器状态、IP 负载均衡器和 VIP 的状态转移等,并不是一个专业的负载均衡器。因此,在使用时需要根据具体的需求进行选择。

3.2 架构上的区别

Haproxy 是一个单点负载均衡器,通过 HA 模式可以实现高可用性,但不能实现负载均衡器的冗余。而 Keepalived 可以支持设立多个负载均衡器,实现多机热备,建立平衡负载和高可用性的热备,提高了系统的可靠性。

3.3 配置上的区别

Haproxy 和 Keepalived 的配置方式大不相同。Haproxy 通过配置文件进行配置,支持灵活的负载均衡方式和算法。而 Keepalived 需要在网络中使用虚拟路由协议(VRRP)进行配置,这涉及到路由器、交换机等网络设备的支持,比较复杂。

在这里插入图片描述

4.总结

本文从负载均衡器的介绍和基本概念、特点入手,着重分析了 Haproxy 和 Keepalived 在功能、架构和配置方面的区别。可以看出,Haproxy 是一种集成度较高、使用简单、灵活的负载均衡器软件,适合低负载的环境;而 Keepalived 则可以支持负载均衡器的冗余,实现多机热备,具有更高的系统可靠性。因此,在实际应用中需要根据自身的需求进行选择,避免因应用环境选择不当而导致系统问题。

相关文章:

【高可用架构】Haproxy 和 Keepalived 的区别

Haproxy 和 Keepalived 的区别 1.负载均衡器介绍2.Haproxy 和 Keepalived 的基本概念和特点2.1 Haproxy2.2 Keepalived 3.Haproxy 和 Keepalived 的区别3.1 功能上的区别3.2 架构上的区别3.3 配置上的区别 4.总结 1.负载均衡器介绍 负载均衡器是一种解决高并发和高可用的常用的…...

python-opencv 人脸68点特征点检测

python-opencv 人脸68点特征点检测 不是很难,主要还是掉包,来看一下代码啊: # coding: utf-8 # 导包 import numpy as np import dlib import cv2class face_emotion(object):def __init__(self):# 人脸检测器对象,通过它拿到人…...

无线网络下VMWare+CentOS7使用桥接模式无法联通网络问题

因为最近新配了台带无线网卡的主机,所以准备把所有的内容都转移到新电脑上,其中就包括虚拟机 安装好VMWareCentOS7选择桥接模式 然后我们去修改一下网络配置 cd /etc/sysconfig/network-scripts/进入这个ifcfg-ens33文件 我们修改箭头所示内容&#xff…...

vue2.x中使用JS与路由守卫配置、vue2.x中使用TS与路由守卫的配置和vuex的配置以及TS在vue2.x中的使用说明

vue2.x 事件修饰符 <button click.stop.self"handleDelete(item)"></button>在使用 $confirm 时&#xff0c;使用 await 方式时&#xff0c;需要添加 catch 回调&#xff0c;否则无法获取 $confirm 关闭和取消时的标识值&#xff0c;并且后续代码停止执…...

C语言第三十二弹---打印整数二进制的奇数位和偶数位

使用C语言打印整数二进制的奇数位和偶数位。 思路&#xff1a;分别实现奇数位和偶数位&#xff0c;那么二进制只有0 和 1 那么如何判断一个数的二进制位是0还是1呢?那我们就可以使用位操作符&与1比较&#xff0c;都是1证明该二进制位是1&#xff0c;为0证明该二进制位是0…...

车载电子电器架构 ——电子电气架构设计方案概述

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 注:本文1万多字,认证码字,认真看!!! 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证…...

《C++PrimePlus》第10章 对象和类

10.1 过程性编程和面向对象编程 10.2 抽象和类 10.3 类的构造函数和析构函数 类的定义和使用&#xff08;买卖股票&#xff09; 头文件stock10.h #ifndef __STOCK00__H__ #define __STOCK00__H__#include <string>class Stock { // pravate的内容只能通过public访问 p…...

实现极坐标图表QPolarChart的角度轴范围是[0,360]时,0度在水平右侧

目录 参考角度轴范围是[0,360]时&#xff0c;0度在水平右侧.h.cpp 参考 Qt数据可视化(QPolarChart雷达图) 默认QPolarChart的范围是[0,360]时&#xff0c;0度在垂直上方 如官方例子QValueAxis角度轴范围是[-100,100] 角度轴范围是[0,360]时&#xff0c;0度在水平右侧 原理&am…...

讲述 什么是鸿蒙 为什么需要鸿蒙 为什么要学习鸿蒙

首先 我们为什么要学习鸿蒙开发&#xff1f; 因为 鸿蒙发展前景巨大 鸿蒙自发布依赖 一直受社会各界关注 强两百的 App厂商 大部分接受了与鸿蒙的合作 硬件也有非常多与鸿蒙合作的厂商 鸿蒙的合作企业基本已经覆盖整个互联网客户的主流需求 所以鸿蒙的崛起不过是早晚的问题 …...

【深度学习笔记】05 线性回归

线性回归 线性回归基于几个简单的假设&#xff1a; 首先&#xff0c;假设自变量 x \mathbf{x} x和因变量 y y y之间的关系是线性的&#xff0c; 即 y y y可以表示为 x \mathbf{x} x中元素的加权和&#xff0c;这里通常允许包含观测值的一些噪声&#xff1b; 其次&#xff0c;我…...

二叉树算法—后继节点

与其明天开始&#xff0c;不如现在行动&#xff01; 文章目录 1 后继节点1.1 解题思路1.2 代码实现 &#x1f48e;总结 1 后继节点 1.1 解题思路 二叉树节点结构定义如下&#xff1a; public static class Node { public int cal; public Node left; public Node right; public…...

C语言做一个恶作剧关机程序

一、项目介绍 C语言实现一个简单的"流氓软件"&#xff0c;一个可以强制关机恶作剧关机程序&#xff0c;输入指定指令可以解除 二、运行截图 然后当你输入“n”才可以解锁关机。 三、完整源码 #include <stdlib.h> #include <stdio.h> #include <s…...

数据结构 / 计算机内存分配

1. Linux 32位系统内存分配 栈(stack): 先进后出, 栈区变量先定义的后分配内存, 栈区地址从高到低分配堆(heap): 先进先出, 栈区变量先定义的先分配内存, 堆区地址从低到高分配堆栈溢出: 表示的是栈区内存耗尽, 称为溢出. 例如: 每次调用递归都需要在栈区申请内存, 如果递归太深…...

计算机视觉算法——基于Transformer的目标检测(DN DETR / DINO / Sparser DETR / Lite DETR)

计算机视觉算法——基于Transformer的目标检测&#xff08;DN DETR / DINO&#xff09; 计算机视觉算法——基于Transformer的目标检测&#xff08;DN DETR / DINO&#xff09;1. DN DETR1.1 Stablize Hungarian Matching1.2 Denoising1.3 Attention Mask 2. DINO2.1 Contrasti…...

Spark---基于Yarn模式提交任务

Yarn模式两种提交任务方式 一、yarn-client提交任务方式 1、提交命令 ./spark-submit --master yarn --class org.apache.spark.examples.SparkPi ../examples/jars/spark-examples_2.11-2.3.1.jar 100 或者 ./spark-submit --master yarn–client --class org.apache.s…...

SpringCloud之Gateway(统一网关)

文章目录 前言一、搭建网关服务1、导入依赖2、在application.yml中写配置 二、路由断言工厂Route Predicate Factory三、路由过滤器 GatewayFilter案例1给所有进入userservice的请求添加一个请求头总结 四、全局过滤器 GlobalFilter定义全局过滤器&#xff0c;拦截并判断用户身…...

案例029:基于微信小程序的阅读网站设计与实现

文末获取源码 开发语言&#xff1a;Java 框架&#xff1a;SSM JDK版本&#xff1a;JDK1.8 数据库&#xff1a;mysql 5.7 开发软件&#xff1a;eclipse/myeclipse/idea Maven包&#xff1a;Maven3.5.4 小程序框架&#xff1a;uniapp 小程序开发软件&#xff1a;HBuilder X 小程序…...

27. Spring源码篇之SpEL表达式之自定义解析模版

简介 其实前面文章我们已经介绍过了如何定义spring表达式的解析模版&#xff0c;但是那是直接使用表达式api的形式&#xff0c;对于使用spring的同学来说&#xff0c;更优雅的方式就是可以自定义一个扩展去修改 本文就是介绍如何通过Spring的扩展点修改表达式解析模版 自定义…...

100天精通Python(可视化篇)——第109天:Pyecharts绘制各种常用地图(参数说明+代码实战)

文章目录 专栏导读一、地图应用场景二、参数说明1. 导包2. add函数 三、地图绘制实战1. 省市地图2. 中国地图3. 中国地图&#xff08;带城市&#xff09;4. 中国地图&#xff08;分段型&#xff09;5. 中国地图&#xff08;连续型&#xff09;6. 世界地图7. 行程轨迹地图8. 人口…...

bugku 渗透测试

场景1 查看源代码 场景2 用dirsearch扫描一下看看 ok看到登录的照应了第一个提示 进去看看 不出所料 随便试试admin/admin进去了 在基本设置里面看到falg 场景3 确实是没啥想法了 找到php在线运行 检查网络&#xff0c;我们发现这个php在线运行会写入文件 那我们是不是写…...

金融行情API对接指南:WebSocket实时订阅外汇/期货/数字货币(附代码示例)

引言在量化交易或金融看盘软件开发中&#xff0c;获取低延迟的实时行情&#xff08;Tick级数据&#xff09;是核心环节。传统的HTTP轮询不仅效率低&#xff0c;且容易触发风控。目前主流方案是采用WebSocket协议实现全双工通信&#xff0c;服务端主动推送&#xff0c;极大降低资…...

Windows大数据开发环境搭建完整指南:使用winutils解决Hadoop兼容性问题

Windows大数据开发环境搭建完整指南&#xff1a;使用winutils解决Hadoop兼容性问题 【免费下载链接】winutils Windows binaries for Hadoop versions (built from the git commit ID used for the ASF relase) 项目地址: https://gitcode.com/gh_mirrors/wi/winutils 对…...

【生产环境亲测】HANA2.0高可用切换实战指南

SLES 15 SP3 + HANA 2.0 SPS06 生产级 HA 手工切换全流程 | 维护模式规范 | 零数据丢失 | Pacemaker 集群运维 文章标签 SAP HANA SLES 15 SP3 高可用切换 Pacemaker SAP Basis 运维实战 数据库维护 一、前言 在 SLES 15 SP3 + SAP HANA 2.0 SPS06 + Pacemaker/Corosync 高可…...

B站m4s转换工具:3分钟解锁缓存视频的终极解决方案

B站m4s转换工具&#xff1a;3分钟解锁缓存视频的终极解决方案 【免费下载链接】m4s-converter 一个跨平台小工具&#xff0c;将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 你是否曾遇到过这样的困扰&#xf…...

基于transformer的clip和blip之间的关系、原理、方法实现和直观可视化

Transformer 是通用的注意力底座架构&#xff1b;CLIP 是把图像和文本映射到同一语义空间做对齐&#xff1b;BLIP 则在图文对齐之外&#xff0c;进一步把“理解”和“生成”放进同一个视觉语言预训练框架里。原始 Transformer 用纯注意力替代 RNN/CNN&#xff1b;CLIP 使用图像…...

FLUX.2-klein-base-9b-nvfp4系统资源监控与优化:保障稳定运行

FLUX.2-klein-base-9b-nvfp4系统资源监控与优化&#xff1a;保障稳定运行 最近在星图GPU平台上部署了FLUX.2-klein-base-9b-nvfp4模型&#xff0c;跑起来效果确实不错。但用了一段时间后&#xff0c;我发现一个问题&#xff1a;模型服务偶尔会变慢&#xff0c;甚至卡住不动。一…...

【网络安全】从零开始:15种常见网络攻击类型及防御措施全解析,小白必备!建议收藏学习!

【网络安全】从零开始&#xff1a;15种常见网络攻击类型及防御措施全解析&#xff0c;小白必备&#xff01;建议收藏学习&#xff01; 随着攻击者效率和复杂性的提高&#xff0c;网络犯罪每年都在急剧增加。[网络攻击]的发生有多种不同的原因和多种不同的方式。但是&#xff0c…...

农村与中小城市的数字化,藏着被忽略的技术蓝海

被忽视的数字新大陆当一线城市的数字化转型趋于饱和&#xff0c;农村与中小城市正悄然成为技术落地的"价值洼地"。这片蓝海蕴藏着庞大的场景创新空间&#xff0c;却因基础设施薄弱、用户群体特殊、生态体系未成型等痛点被长期忽视。对软件测试从业者而言&#xff0c;…...

【系统架构师-案例题-建模分析】21年下(4)预约挂号管理系统 UML 建模案例分析

文章目录题目【问题1】(6分)【问题2】(10分)【问题3】(9分)答案与解答【问题1】答案解答【问题2】答案顺序图与协作图的区别解答【问题3】答案1. 三种模型的定义2. 三种模型的关联关系3. 需求分析阶段的适用性解答题目 某医院拟委托软件公司开发一套预约挂号管理系统&#xff…...

三星固件下载神器:Bifrost跨平台解决方案完全指南

三星固件下载神器&#xff1a;Bifrost跨平台解决方案完全指南 【免费下载链接】SamloaderKotlin 项目地址: https://gitcode.com/gh_mirrors/sa/SamloaderKotlin 三星固件下载神器Bifrost&#xff08;SamloaderKotlin&#xff09;是一款免费开源的三星官方固件下载工具…...