当前位置: 首页
系统平台
Linux Keepalived高可用配置教程 双机热备实战指南

Linux Keepalived高可用配置教程 双机热备实战指南

热心网友 时间:2026-05-20
转载

配置Keepalived实现双机热备,一个常见的误解是认为软件装上就能自动实现高可用。实际上,真正的稳定运行,关键在于VRRP配置、健康检查绑定以及网络层对齐这三者必须严丝合缝。任何一个环节出错,比如virtual_router_id不一致,或者健康检查脚本失效,都可能导致虚拟IP(VIP)无法正常漂移,服务依然中断。

Linux怎么配置Keepalived实现高可用 Linux双机热备配置详解

确认网卡名和VIP网段是否真实可达

很多部署后的问题,根源在于“以为网络是通的,但实际上不通”。这需要从最底层开始确认:首先,VIP必须与两台服务器的物理IP处于同一个子网。其次,配置文件中指定的网卡名称,必须与系统内实际名称完全匹配(例如是ens33还是eth0,不同CentOS版本差异可能很大)。

  • 第一步,在两台服务器上执行ip -br a命令,确认目标网卡状态为UP,并且已经分配了同网段的IP地址(例如192.168.100.11/24)。
  • 规划的VIP地址(如192.168.100.107)不能与现有物理IP、网关地址或广播地址冲突。
  • 防火墙必须放行VRRP协议通信。VRRP默认使用组播地址224.0.0.18和协议号112。以firewalld为例,可以执行命令:firewall-cmd --add-rich-rule='rule protocol value="vrrp" accept' --permanent,然后重载配置。
  • 如果系统启用了SELinux,需要确保Keepalived进程有权限读取自定义脚本,可以执行setsebool -P keepalived_read_etc 1来设置。

state、priority和virtual_router_id必须成对校验

vrrp_instance配置块中,statepriorityvirtual_router_id这三个参数是主备节点相互识别的核心,任何一项不匹配都可能导致脑裂或状态异常。

  • state参数:主节点配置应设为MASTER,备节点必须设为BACKUP。如果写反了,配置本身不会报错,但VIP将无法按预期漂移。
  • priority参数:主节点的优先级应高于备节点。通常主节点设为100,备节点设为90,保持至少10的差值可以在网络轻微抖动时避免误切换。
  • virtual_router_id参数:同一个VRRP实例在两台机器上的这个ID必须完全相同(取值范围1-255),并且在同一局域网内,不同的VRRP组必须使用不同的ID,否则会相互干扰。

健康检查脚本必须返回正确的exit code并可执行

依靠自定义脚本(如killall -0 nginxcurl -s http://127.0.0.1/health)来检测应用状态是标准做法,但脚本本身常常成为故障点。

  • 脚本路径必须与vrrp_script中定义的完全一致(例如/etc/keepalived/check_nginx.sh),并且确保其具有可执行权限(chmod 755),属主为root
  • 脚本的退出码必须明确:健康时返回exit 0,异常时返回exit 1(或其他非零值)。返回其他特定值(如exit 2)可能会被Keepalived忽略。
  • 在脚本中,避免使用依赖完整系统环境的命令,例如systemctl is-active nginx。因为Keepalived的子进程可能无法加载全部systemd环境变量。改用pgrep -x nginx这类命令会更可靠。
  • 检查间隔interval建议设置为2秒左右。间隔太短会增加系统负载,间隔太长(如超过5秒)则会延长故障发现时间,影响服务可用性。

切记:Keepalived不同步数据,只管VIP漂移

这是一个至关重要的认知:Keepalived只负责IP地址的高可用,它不负责数据同步。有人配置好后以为高枕无忧,结果主服务器宕机后,VIP虽然漂移到了备机,但备机上的数据库却是空的——因为Keepalived从不复制磁盘数据、不同步文件、也不处理数据库日志。

  • 它的核心工作非常单一:当通过健康检查判断本地服务异常时,自动降低自身优先级,触发备节点升为主节点并接管VIP。
  • 对于Nginx静态资源,需要通过rsync或分布式存储等方式保证文件一致。对于MySQL、PostgreSQL等数据库,必须单独配置主从复制或流复制。
  • 如果使用corosync + pacemaker这类集群栈来同时管理数据库服务和VIP,必须正确配置colocation约束,否则可能出现VIP和数据库服务分别运行在不同节点上的情况,服务依然不可用。

说到底,要让双机热备真正稳定运行,最常遇到的障碍往往不是配置文件的语法错误,而是网络层组播通信是否畅通、健康检查脚本是否存在静默失败,以及是否清晰理解了“VIP切换”并不等同于“服务全自动恢复”这个根本逻辑。

来源:https://www.php.cn/faq/2412908.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
Windows蓝屏代码0x000000d1驱动程序错误修复指南

Windows蓝屏代码0x000000d1驱动程序错误修复指南

当电脑屏幕突然变蓝,并显示“0x000000D1 (IRQL_NOT_LESS_OR_EQUAL)”错误代码时,这通常意味着驱动程序发生了内存访问冲突。通俗地讲,就是某个驱动程序试图在错误的时机访问系统内核内存区域,从而触发了系统保护机制。此类蓝屏问题多由驱动程序与系统版本不兼容、驱动程序更新失败或

时间:2026-05-20 08:45
Windows查看网络占用进程教程 快速定位高流量程序

Windows查看网络占用进程教程 快速定位高流量程序

当您发现网络速度突然下降或数据流量消耗异常增加时,很可能是因为某个后台程序正在占用大量带宽。不必担心,Windows系统自身提供了强大的诊断工具,结合一些实用的第三方软件,可以快速准确地找出消耗网络资源的进程。 一、使用资源监视器精确定位实时高流量进程 资源监视器是Windows系统内置的专业级网络

时间:2026-05-20 08:45
彻底关闭Win10自动更新:禁用后台更新进程的终极方法

彻底关闭Win10自动更新:禁用后台更新进程的终极方法

最彻底的解决方案是执行五步协同禁用策略:一、禁用wuauserv UsoSvc BITS三项核心服务;二、通过组策略编辑器禁用自动更新并隐藏相关界面;三、禁用Windows Update相关的计划任务;四、在注册表中设置NoAutoUpdate=1及Start=4;五、在用户配置层面同步锁定更新策略

时间:2026-05-20 08:45
Mac终端查看IP地址的详细方法与常用网络指令

Mac终端查看IP地址的详细方法与常用网络指令

在Mac上排查网络问题,或者需要配置一些服务时,查看本机的IP地址往往是第一步。虽然图形界面也能找到,但对于开发者或习惯使用命令行的用户来说,终端无疑更高效直接。今天,我们就来梳理一下在终端里查看IP地址的几种核心方法,从最常用的到应对特殊场景的,帮你快速定位所需信息。 一、使用 ipconfig

时间:2026-05-20 08:45
苹果电脑连接双显示器设置教程

苹果电脑连接双显示器设置教程

Mac连接两台外接显示器时,只亮一台或画面错乱?这通常不是硬件故障,而是设置环节出了问题。从设备兼容性、线缆规格到连接方法,每个细节都至关重要。本文将为你提供一份详尽的Mac双屏显示设置指南,彻底解决连接难题。 一、确认你的Mac是否支持双屏显示 这是成功连接的基础。如果Mac硬件本身不支持,后续操

时间:2026-05-20 08:45
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程