【高可用架构】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.负载均衡器介绍
负载均衡器是一种解决高并发和高可用的常用的网络设备,它可以将流量分摊到多台服务器上,实现负载均衡,提高业务处理效率和稳定性。在负载均衡器的选择上,Haproxy 和 Keepalived 是两个常用的开源负载均衡器。
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文件 我们修改箭头所示内容ÿ…...
vue2.x中使用JS与路由守卫配置、vue2.x中使用TS与路由守卫的配置和vuex的配置以及TS在vue2.x中的使用说明
vue2.x 事件修饰符 <button click.stop.self"handleDelete(item)"></button>在使用 $confirm 时,使用 await 方式时,需要添加 catch 回调,否则无法获取 $confirm 关闭和取消时的标识值,并且后续代码停止执…...
C语言第三十二弹---打印整数二进制的奇数位和偶数位
使用C语言打印整数二进制的奇数位和偶数位。 思路:分别实现奇数位和偶数位,那么二进制只有0 和 1 那么如何判断一个数的二进制位是0还是1呢?那我们就可以使用位操作符&与1比较,都是1证明该二进制位是1,为0证明该二进制位是0…...
车载电子电器架构 ——电子电气架构设计方案概述
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 注:本文1万多字,认证码字,认真看!!! 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证…...
《C++PrimePlus》第10章 对象和类
10.1 过程性编程和面向对象编程 10.2 抽象和类 10.3 类的构造函数和析构函数 类的定义和使用(买卖股票) 头文件stock10.h #ifndef __STOCK00__H__ #define __STOCK00__H__#include <string>class Stock { // pravate的内容只能通过public访问 p…...
实现极坐标图表QPolarChart的角度轴范围是[0,360]时,0度在水平右侧
目录 参考角度轴范围是[0,360]时,0度在水平右侧.h.cpp 参考 Qt数据可视化(QPolarChart雷达图) 默认QPolarChart的范围是[0,360]时,0度在垂直上方 如官方例子QValueAxis角度轴范围是[-100,100] 角度轴范围是[0,360]时,0度在水平右侧 原理&am…...
讲述 什么是鸿蒙 为什么需要鸿蒙 为什么要学习鸿蒙
首先 我们为什么要学习鸿蒙开发? 因为 鸿蒙发展前景巨大 鸿蒙自发布依赖 一直受社会各界关注 强两百的 App厂商 大部分接受了与鸿蒙的合作 硬件也有非常多与鸿蒙合作的厂商 鸿蒙的合作企业基本已经覆盖整个互联网客户的主流需求 所以鸿蒙的崛起不过是早晚的问题 …...
【深度学习笔记】05 线性回归
线性回归 线性回归基于几个简单的假设: 首先,假设自变量 x \mathbf{x} x和因变量 y y y之间的关系是线性的, 即 y y y可以表示为 x \mathbf{x} x中元素的加权和,这里通常允许包含观测值的一些噪声; 其次,我…...
二叉树算法—后继节点
与其明天开始,不如现在行动! 文章目录 1 后继节点1.1 解题思路1.2 代码实现 💎总结 1 后继节点 1.1 解题思路 二叉树节点结构定义如下: public static class Node { public int cal; public Node left; public Node right; public…...
C语言做一个恶作剧关机程序
一、项目介绍 C语言实现一个简单的"流氓软件",一个可以强制关机恶作剧关机程序,输入指定指令可以解除 二、运行截图 然后当你输入“n”才可以解锁关机。 三、完整源码 #include <stdlib.h> #include <stdio.h> #include <s…...
数据结构 / 计算机内存分配
1. Linux 32位系统内存分配 栈(stack): 先进后出, 栈区变量先定义的后分配内存, 栈区地址从高到低分配堆(heap): 先进先出, 栈区变量先定义的先分配内存, 堆区地址从低到高分配堆栈溢出: 表示的是栈区内存耗尽, 称为溢出. 例如: 每次调用递归都需要在栈区申请内存, 如果递归太深…...
计算机视觉算法——基于Transformer的目标检测(DN DETR / DINO / Sparser DETR / Lite DETR)
计算机视觉算法——基于Transformer的目标检测(DN DETR / DINO) 计算机视觉算法——基于Transformer的目标检测(DN DETR / DINO)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定义全局过滤器,拦截并判断用户身…...
案例029:基于微信小程序的阅读网站设计与实现
文末获取源码 开发语言:Java 框架:SSM JDK版本:JDK1.8 数据库:mysql 5.7 开发软件:eclipse/myeclipse/idea Maven包:Maven3.5.4 小程序框架:uniapp 小程序开发软件:HBuilder X 小程序…...
27. Spring源码篇之SpEL表达式之自定义解析模版
简介 其实前面文章我们已经介绍过了如何定义spring表达式的解析模版,但是那是直接使用表达式api的形式,对于使用spring的同学来说,更优雅的方式就是可以自定义一个扩展去修改 本文就是介绍如何通过Spring的扩展点修改表达式解析模版 自定义…...
100天精通Python(可视化篇)——第109天:Pyecharts绘制各种常用地图(参数说明+代码实战)
文章目录 专栏导读一、地图应用场景二、参数说明1. 导包2. add函数 三、地图绘制实战1. 省市地图2. 中国地图3. 中国地图(带城市)4. 中国地图(分段型)5. 中国地图(连续型)6. 世界地图7. 行程轨迹地图8. 人口…...
bugku 渗透测试
场景1 查看源代码 场景2 用dirsearch扫描一下看看 ok看到登录的照应了第一个提示 进去看看 不出所料 随便试试admin/admin进去了 在基本设置里面看到falg 场景3 确实是没啥想法了 找到php在线运行 检查网络,我们发现这个php在线运行会写入文件 那我们是不是写…...
地震勘探——干扰波识别、井中地震时距曲线特点
目录 干扰波识别反射波地震勘探的干扰波 井中地震时距曲线特点 干扰波识别 有效波:可以用来解决所提出的地质任务的波;干扰波:所有妨碍辨认、追踪有效波的其他波。 地震勘探中,有效波和干扰波是相对的。例如,在反射波…...
Unity3D中Gfx.WaitForPresent优化方案
前言 在Unity中,Gfx.WaitForPresent占用CPU过高通常表示主线程在等待GPU完成渲染(即CPU被阻塞),这表明存在GPU瓶颈或垂直同步/帧率设置问题。以下是系统的优化方案: 对惹,这里有一个游戏开发交流小组&…...
多种风格导航菜单 HTML 实现(附源码)
下面我将为您展示 6 种不同风格的导航菜单实现,每种都包含完整 HTML、CSS 和 JavaScript 代码。 1. 简约水平导航栏 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport&qu…...
Mobile ALOHA全身模仿学习
一、题目 Mobile ALOHA:通过低成本全身远程操作学习双手移动操作 传统模仿学习(Imitation Learning)缺点:聚焦与桌面操作,缺乏通用任务所需的移动性和灵活性 本论文优点:(1)在ALOHA…...
C++课设:简易日历程序(支持传统节假日 + 二十四节气 + 个人纪念日管理)
名人说:路漫漫其修远兮,吾将上下而求索。—— 屈原《离骚》 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 专栏介绍:《编程项目实战》 目录 一、为什么要开发一个日历程序?1. 深入理解时间算法2. 练习面向对象设计3. 学习数据结构应用二、核心算法深度解析…...
鸿蒙(HarmonyOS5)实现跳一跳小游戏
下面我将介绍如何使用鸿蒙的ArkUI框架,实现一个简单的跳一跳小游戏。 1. 项目结构 src/main/ets/ ├── MainAbility │ ├── pages │ │ ├── Index.ets // 主页面 │ │ └── GamePage.ets // 游戏页面 │ └── model │ …...
Python实现简单音频数据压缩与解压算法
Python实现简单音频数据压缩与解压算法 引言 在音频数据处理中,压缩算法是降低存储成本和传输效率的关键技术。Python作为一门灵活且功能强大的编程语言,提供了丰富的库和工具来实现音频数据的压缩与解压。本文将通过一个简单的音频数据压缩与解压算法…...
面试高频问题
文章目录 🚀 消息队列核心技术揭秘:从入门到秒杀面试官1️⃣ Kafka为何能"吞云吐雾"?性能背后的秘密1.1 顺序写入与零拷贝:性能的双引擎1.2 分区并行:数据的"八车道高速公路"1.3 页缓存与批量处理…...
JUC并发编程(二)Monitor/自旋/轻量级/锁膨胀/wait/notify/锁消除
目录 一 基础 1 概念 2 卖票问题 3 转账问题 二 锁机制与优化策略 0 Monitor 1 轻量级锁 2 锁膨胀 3 自旋 4 偏向锁 5 锁消除 6 wait /notify 7 sleep与wait的对比 8 join原理 一 基础 1 概念 临界区 一段代码块内如果存在对共享资源的多线程读写操作…...
解密鸿蒙系统的隐私护城河:从权限动态管控到生物数据加密的全链路防护
摘要 本文以健康管理应用为例,展示鸿蒙系统如何通过细粒度权限控制、动态权限授予、数据隔离和加密存储四大核心机制,实现复杂场景下的用户隐私保护。我们将通过完整的权限请求流程和敏感数据处理代码,演示鸿蒙系统如何平衡功能需求与隐私安…...
