news 2026/5/30 13:19:12

Keepalived详解:安装与高可用集群配置

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Keepalived详解:安装与高可用集群配置

Keepalived详解:原理、编译安装与高可用集群配置


在高可用架构中,避免单点故障至关重要。Keepalived正是为了解决这一问题而生的轻量级工具。本文将深入浅出地介绍Keepalived的工作原理,并提供从编译安装到实战配置的完整指南。

1. Keepalived简介与工作原理

Keepalived是一个基于VRRP协议(虚拟路由冗余协议)实现的高可用解决方案。它的核心目标是通过自动故障转移来确保服务的连续性。

1.1核心思想:VRRP协议

想象一个场景:两台路由器提供相同的功能,一台是主节点(Master),另一台是备节点(Backup)。它们共同拥有一个虚拟IP地址(VIP,Virtual IP),客户端只访问这个VIP。

  • 正常工作:主节点持有VIP并对外提供服务。它会周期性地向备份节点发送VRRP通告包(组播地址为224.0.0.18),宣告自己“健在”。
  • 故障发生:当备份节点在指定时间内收不到主节点的VRRP通告包时,它会认为主节点发生了故障。
  • 自动切换:此时,备份节点会根据优先级选举(优先级最高的备份节点获胜)接管VIP,并将其绑定到自己的网络接口上,从而无缝地接替主节点继续提供服务。这个过程对客户端来说是透明的,从而实现了高可用。

1.2 Keepalived的三大模块

Keepalived主要由三个模块构成:

  1. Core模块:作为核心,负责主进程的启动、维护及全局配置文件的加载和解析。
  2. Check模块:负责健康检查,支持对负载均衡器后端的真实服务器进行TCP检查、HTTP_GET检查等,确保只有健康的服务器才接收流量。
  3. VRRP模块:这是实现VRRP协议的功能模块,负责处理主备节点间的通信和状态切换。

2.安装Keepalived

安装Keepalived主要有两种方式:通过系统包管理器安装和通过源代码编译安装。前者简单快捷,后者则能提供更新的版本和更灵活的定制选项。

2.1 YUM安装(快速上手)

在基于RHEL/CentOS的系统上,可以使用yum命令直接安装:

yum install keepalived -y

安装后,可以使用systemctl命令来管理服务:

systemctl start keepalived.service # 启动

systemctl enable keepalived.service # 设置开机自启

systemctl status keepalived.service # 查看状态

2.2源码编译安装(推荐用于生产)

源码安装可以获得最新版本,并允许进行自定义配置。

步骤1:安装依赖包
编译前需要安装必要的开发工具和库:

yum install -y gcc openssl-devel libnl3-devel libnfnetlink-devel net-snmp-devel curl make

步骤2:下载、编译与安装
从官方下载源码包,然后进行编译安装。使用 --prefix 参数可以指定安装目录,便于管理。

# 进入常用源码目录,下载(请替换为最新稳定版链接)

cd /usr/local/src/

curl -O http://keepalived.org/software/keepalived-2.2.4.tar.gz

# 或使用 wget https://www.keepalived.org/software/keepalived-2.2.4.tar.gz

# 解压并进入目录

tar xvf keepalived-2.2.4.tar.gz

cd keepalived-2.2.4

# 配置、编译并安装

./configure --prefix=/usr/local/keepalived

make && make install

步骤3:配置系统服务
为了方便管理,需要将Keepalived配置为系统服务。

  • 将启动脚本复制到系统目录:

cp /usr/local/src/keepalived-2.2.4/keepalived/keepalived.service /usr/lib/systemd/system/

  • 重新加载systemd配置:

systemctl daemon-reload

3.配置Keepalived实现主备高可用

下面以配置一个简单的主备高可用集群为例。假设我们有两台服务器:

  • 主节点(Master:物理IP为 192.168.10.11
  • 备节点(Backup:物理IP为 192.168.10.12
  • 虚拟IP(VIP:192.168.10.100

3.1主节点(Master)配置

编辑配置文件 /etc/keepalived/keepalived.conf(如果源码安装,可能需要手动创建/etc/keepalived目录并将配置文件放置于此):

! Configuration File for keepalived

global_defs {

router_id LVS_MASTER_01 # 本节点标识,建议唯一

}

vrrp_instance VI_1 {

state MASTER # 初始状态设为MASTER

interface eth0 # 监听VRRP通告和绑定VIP的网卡名,请根据实际情况修改

virtual_router_id 51 # 虚拟路由ID,同一集群内主备节点必须相同(0-255)

priority 100 # 优先级(1-254),主节点应高于备节点

advert_int 1 # 通告间隔(秒)

unicast_src_ip 192.168.10.101 # 本机的真实IP地址

unicast_peer {

192.168.10.102 # 对端备节点的真实IP地址

}

authentication { # 认证配置,主备需一致

auth_type PASS # 认证类型

auth_pass 1111 # 认证密码

}

virtual_ipaddress {

192.168.10.100/24 # 定义的虚拟IP(VIP),可多个

}

}

3.2备节点(Backup)配置

备节点的配置与主节点相似,主要区别在于 state 和 priority。

! Configuration File for keepalived

global_defs {

router_id LVS_BACKUP_01 # 备节点标识

}

vrrp_instance VI_1 {

state BACKUP # 初始状态设为BACKUP

interface eth0

virtual_router_id 51 # 必须与主节点相同

priority 90 # 优先级低于主节点

advert_int 1

unicast_src_ip 192.168.10.102 # 本机的真实IP地址

unicast_peer {

192.168.10.101 # 对端备节点的真实IP地址

}

authentication {

auth_type PASS

auth_pass 1111 # 密码与主节点相同

}

virtual_ipaddress {

192.168.10.100/24

}

}

3.3启动服务并验证

  1. 启动服务:在主备节点上分别启动Keepalived。

systemctl start keepalived

  1. 检查虚拟IP:在主节点上执行 ip addr show eth0 命令,应该能看到VIP 19168.10.100 已经绑定在 eth0 网卡上。

2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000

link/ether 00:0c:29:xx:xx:xx brd ff:ff:ff:ff:ff:ff

inet 192.168.10.11/24 brd 192.168.10.255 scope global noprefixroute eth0

valid_lft forever preferred_lft forever

inet 192.168.10.100/24 scope global secondary eth0:0

valid_lft forever preferred_lft forever

  1. 模拟故障测试:将主节点的Keepalived服务停止(systemctl stop keepalived)或直接关闭主服务器。然后在备节点上再次执行 ip addr 命令,会发现VIP已经"漂移"到了备节点上。此时通过VIP访问服务,应仍然正常,从而实现了高可用。

4.核心配置参数解析

下表总结了关键配置参数的含义:

参数项

含义与说明

global_defs

全局配置段

router_id

本机标识,通常使用主机名,用于在集群中区分不同节点

vrrp_instance

定义一个VRRP实例(一个虚拟路由器)

state

初始状态,MASTERBACKUP,但最终状态由优先级决定

interface

绑定VIP和发送VRRP通告的物理网卡

virtual_router_id

虚拟路由ID,同一组主备节点必须完全相同

priority

优先级(1-254),决定谁成为Master,值越大优先级越高

advert_int

主节点发送VRRP通告报文的时间间隔(秒)

authentication

节点间通信认证,防止未经授权的节点加入

auth_type

认证方式,一般为PASS(密码认证)

auth_pass

认证密码,最多8位,主备节点必须一致

virtual_ipaddress

定义的虚拟IP地址,即VIP

5.非抢占模式

默认情况下,Keepalived工作在抢占模式。这意味着当原Master节点恢复后,它会重新抢占VIP,夺回Master身份。在某些场景下,我们可能希望故障恢复后的节点作为新的备份,以避免服务因再次切换而波动。这时可以配置非抢占模式

在vrrp_instance配置段中添加:

nopreempt # 启用非抢占模式

需要注意的是,在非抢占模式下,初始状态state建议都设置为BACKUP。

总结

Keepalived通过VRRP协议提供了一种简单而高效的高可用解决方案。从理解其核心原理到动手编译安装,再到根据实际需求配置主备或非抢占模式,您已经可以构建基础的高可用集群。在生产环境中,通常还会结合Nginx、LVS、HAProxy等负载均衡器,并编写自定义的健康检查脚本,以构建更加健壮和复杂的应用高可用架构。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/29 20:15:58

语音合成新突破:GPT-SoVITS实现跨语言TTS只需1分钟音频

语音合成新突破&#xff1a;GPT-SoVITS实现跨语言TTS只需1分钟音频 在内容创作日益个性化的今天&#xff0c;越来越多的自媒体人、教育工作者甚至普通用户开始思考一个问题&#xff1a;能不能让AI用我的声音说话&#xff1f; 过去&#xff0c;这听起来像是科幻电影的情节。传统…

作者头像 李华
网站建设 2026/5/29 20:13:28

Java矩阵乘法

任务描述 本关任务&#xff1a;编写一个程序&#xff0c;输入两个矩阵输出矩阵乘的结果。矩阵乘法 矩阵相乘最重要的方法是一般矩阵乘积。它只有在第一个矩阵的列数&#xff08; column &#xff09;和第二个矩阵的行数&#xff08; row &#xff09;相同时才有意义。 矩阵乘法…

作者头像 李华
网站建设 2026/5/29 20:59:29

提高领导能力必看的三本书

很多人一提到“领导力”&#xff0c;就会想到鼓舞人心的演讲、果断的决策、带领团队逆转困境的传奇故事。但现实中&#xff0c;大多数管理者面临的领导挑战&#xff0c;远比这些更细微也更真实——如何让团队信任你、如何在压力下保持判断、如何在复杂环境中做出平衡的选择。领…

作者头像 李华
网站建设 2026/5/29 20:45:41

TensorFlow 2.5-gpu与PyTorch 1.8-gpu安装指南

深度学习双雄&#xff1a;TensorFlow 2.5-gpu 与 PyTorch 1.8-gpu 实战部署指南 在现代 AI 工程实践中&#xff0c;一个稳定、可复现的 GPU 环境往往是项目成败的关键。尽管新版本框架层出不穷&#xff0c;但在企业级系统维护和科研成果落地中&#xff0c;TensorFlow 2.5-gpu …

作者头像 李华
网站建设 2026/5/29 13:26:20

深度学习图像处理(3)----二阶段目标检测

文章目录前言1.深度学习2.two-stage 和one-stage 检测算法一.候选框的提取1. 暴力遍历2.在穷举暴力法的基础上&#xff0c;进行一些剪枝操作&#xff1a;二.选择性搜索&#xff08;SS Selective Search&#xff09;1.去掉冗余的候选区域2.自底向上合并3.合并方法4. 计算相似度的…

作者头像 李华
网站建设 2026/5/29 20:59:23

LobeChat能否实现OCR文字识别集成?图像信息提取路径

LobeChat 与 OCR 集成&#xff1a;让图像“开口说话”的技术路径 在智能对话系统日益普及的今天&#xff0c;用户早已不满足于“打字提问、机器回复”的单一交互模式。越来越多的应用场景要求 AI 能“看懂”图片——比如上传一张发票&#xff0c;希望助手自动提取金额和商户信息…

作者头像 李华