news 2026/6/23 19:07:34

Nginx高可用--Keepalived

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Nginx高可用--Keepalived

文章目录

      • keepalived 的 master 与 backup 配置的区别
      • **Keepalived高可用配置解析**
      • **keepalived高可用脑裂**
        • 可能导致脑裂的情况
        • 解决方案

什么是高可用

一般指2台机器启动着相同的业务系统,当有一台机器 down 机了, 另外一台服务器能快速的接管, 对于访问的用户是无感知的

高可用使用场景

业务系统需要保证 7x24 小时不 DOWN 机, 作为业务来说随时都可用, 让你的业务系统更顽强

keepalived 的 master 与 backup 配置的区别

配置项参数说明Master 节点配置Backup 节点配置
route_idKeepalived 实例的唯一标识(同一 VRRP 组内需不同,用于区分节点)route_id lb01route_id lb02
state节点角色状态(Master 为主动节点,Backup 为备用节点)state Masterstate Backup
priority竞选 MASTER 的优先级(数值越大,优先级越高,Master 需高于 Backup)priority 100priority 99

Keepalived高可用配置解析

对高可用的配置文件进行解析

Configuration Fileforkeepalived#注释global_defs{notification_email{acassen@firewall.loc#5-7发邮件给谁}notification_email_from Alexandre.Cassen@firewall.lo#发邮件发件人smtp_server192.168.200.1#邮件服务器地址smtp_connect_timeout30#超时时间router_id Nginx_01#主备ID不能一样}vrrp_instance VI_1{#实例名称(建议不修)state MASTER#服务器的状态(仅仅是傀儡)interface eth0#通信端口virtual_router_id51#实例的IDpriority150#优先级,主备之间最好相差50advert_int1#心跳间隔(如果一秒没通信备节点马上接管)authentication{auth_type PASS#PASS认证类型,此参数备节点设置和主节点相同auth_pass1111#密码是1111,此参数备节点设置和主节点相同}virtual_ipaddress{#vip(可以多个)172.16.1.11/24#26-28配置vIP地址,绑定在eth0 因为(interface eth0)}}

全局定义块部分:要设置 Keepalived 的通知机制和标识

第4-9行是email通知参数。作用:当LVS发生切换或RS等有故障时,会发邮件报警。这是可选配

notifucation_email指定在keepalived发生事件时,需要发给的email地址,可以有多个,每行一个

第10行是Lvs负载均衡器标示(rote_id)。在一个局域网内,它应该是唯一的

大括号”{}” 用来分隔定义块,因此必须成对出现。如果漏写了,keepalived运行时,不会得到预期的结果。由于定义块内存在嵌套关系,因此很容易遗漏结尾处的花括号,这点要特别注意。

keepalived高可用脑裂

是 Keepalived 部署中最常见的故障问题之一。简单来说,脑裂就是高可用集群的节点之间失去了心跳通信,导致每个节点都认为自己是唯一的 “主节点”,进而同时绑定 VIP、对外提供服务,最终引发集群混乱

可能导致脑裂的情况

服务器网线松动等网络故障

服务器硬件故障发生损坏现象而崩溃

主备都开启firewalld防火墙

Nginx服务死掉等

解决方案

编写检测脚本, 测试如果能ping通主并且备节点还有VIP的话则认为产生了列脑

#!/bin/shlb_vip=172.16.1.3master_ip=172.16.1.5whiletrue;doping-c2-W3-i0.01$master_ip&>/dev/nullif[$?-eq0-a`ipadd|grep"$lb_vip"|wc-l`-eq1];thenecho"warning,ha is split brain"elseecho"ha is ok"fisleep5done
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 17:28:42

小林coding快速原型:1小时打造MVP产品

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个快速原型生成工具,用户输入产品想法(如社交网络、电商平台等),AI自动生成可运行的MVP代码框架。工具应包含基本的前端界面、…

作者头像 李华
网站建设 2026/6/23 22:05:59

零基础教程:VSCode运行Python第一行代码

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 制作一个交互式入门指导应用:1. 可视化指引安装VSCode和Python解释器;2. 通过动画演示创建.py文件、选择解释器的过程;3. 内置简单代码检查器&am…

作者头像 李华
网站建设 2026/6/22 19:54:35

小白也能懂:图解HTTP连接为什么会被提前关闭

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个交互式学习模块,通过动画演示TCP连接生命周期。要求:1. 正常连接流程演示 2. 添加提前关闭的故障场景(服务器主动关闭/客户端超时/网络中…

作者头像 李华
网站建设 2026/6/22 23:05:08

AI智能棋盘使用CAT24C512保存EEPROM参数

AI智能棋盘中的CAT24C512 EEPROM应用深度解析在智能家居和交互式电子设备快速发展的今天,AI智能棋盘正从实验室走向家庭客厅。它不仅能自动识别棋子落位、记录对弈过程,还能通过蓝牙或Wi-Fi连接手机App进行复盘分析,甚至与内置AI实时对战。然…

作者头像 李华
网站建设 2026/6/23 14:22:33

深度解析revive高级特性:注释指令与错误代码配置完全指南

深度解析revive高级特性:注释指令与错误代码配置完全指南 【免费下载链接】revive 🔥 ~6x faster, stricter, configurable, extensible, and beautiful drop-in replacement for golint 项目地址: https://gitcode.com/gh_mirrors/re/revive rev…

作者头像 李华
网站建设 2026/6/22 18:19:28

3分钟原型:用AI验证你的equals/hashCode设计

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个快速原型工具,能够:1. 接收类字段定义输入;2. 即时生成不调用父类的equals/hashCode实现;3. 可视化展示对象比较过程&#x…

作者头像 李华