news 2026/3/28 6:16:46

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/3/21 20:23:08

AI如何帮你一键生成虚拟串口通信程序

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个跨平台虚拟串口通信软件,使用Python实现,要求:1. 支持Windows/Linux/MacOS三平台;2. 提供GUI界面可配置串口参数&#xff08…

作者头像 李华
网站建设 2026/3/24 8:50:48

Flutter炫酷UI设计模板完全指南:10+跨平台界面实战教程

Flutter炫酷UI设计模板完全指南:10跨平台界面实战教程 【免费下载链接】awesome-flutter-ui 10 flutter(android, ios) UI design examples :zap: - login, books, profile, food order, movie streaming, walkthrough, widgets 项目地址: https://gitcode.com/gh…

作者头像 李华
网站建设 2026/3/26 15:09:09

基于朴素贝叶斯电商评价数据情感分析与预测任务书

河北东方学院本科毕业论文(设计)任务书题 目宋体五号居中学 院人工智能学院专 业宋体五号居中班级与教务系统班级一致学生姓名宋体五号居中指导教师张三(讲师)日 期2024年10月20日毕业论文(设计&#xff0…

作者头像 李华
网站建设 2026/3/25 8:49:49

Knockout.js无障碍测试实战指南:让动态内容完美适配屏幕阅读器

Knockout.js无障碍测试实战指南:让动态内容完美适配屏幕阅读器 【免费下载链接】knockout Knockout makes it easier to create rich, responsive UIs with JavaScript 项目地址: https://gitcode.com/gh_mirrors/kn/knockout 在当今追求极致用户体验的开发环…

作者头像 李华
网站建设 2026/3/26 18:49:55

Kotaemon医保政策问答:报销比例一键查询

医保政策问答系统的技术实现探讨在智能问答与自然语言处理技术快速发展的今天,越来越多的公共服务开始向数字化、自动化转型。像“Kotaemon医保政策问答”这类应用,虽然不属于传统意义上的嵌入式或功率电子系统,但其背后依然涉及一系列复杂的…

作者头像 李华
网站建设 2026/3/27 6:46:03

突破传统:CUT3R如何实现动态场景的实时三维建模

突破传统:CUT3R如何实现动态场景的实时三维建模 【免费下载链接】CUT3R Official implementation of Continuous 3D Perception Model with Persistent State 项目地址: https://gitcode.com/gh_mirrors/cu/CUT3R 在计算机视觉领域,实时三维感知模…

作者头像 李华