当前位置: 首页 > news >正文

基于keepalived、vip实现高可用nginx (centos)

基于keepalived、vip实现高可用nginx (centos)

1、安装keepalived

yum install keepalived

2、选同一局域网空置ip作vip

我这里测试是:
主:192.168.163.134
副:192.168.163.135
vip:192.168.163.140

3、keepalived配置

nginx检测脚本 (两台用一样脚本即可)

#!/bin/bash# 检查 Nginx 主进程是否存在(通过绝对路径匹配)
if ! pgrep -f "/usr/local/nginx/sbin/nginx" >/dev/null; then# 如果 Nginx 未运行,尝试重启(可选)/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf || exit 1sleep 1  # 等待重启完成# 再次检查,如果仍失败则返回错误pgrep -f "/usr/local/nginx/sbin/nginx" || exit 1
fi
exit 0

主vim /etc/keepalived/keepalived.conf

global_defs {router_id LVS_DEVEL
}# 添加 Nginx 健康检查脚本配置
vrrp_script chk_nginx {script "/etc/keepalived/check_nginx.sh"interval 2   # 每2秒检查一次weight -20   # 如果脚本返回非0,优先级降低20(确保备节点接管)fall 2       # 连续2次失败才认为故障rise 1       # 1次成功就认为恢复
}vrrp_instance VI_1 {state MASTER #主节点interface ens33 ## 绑定虚拟IP的网络接口(网卡),与本机IP地址所在的网络接口相同(我这里是eth0)virtual_router_id 140 ## 虚拟路由ID号(主备节点一定要相同)priority 100mcast_src_ip 192.168.163.134 ## 本机ip地址advert_int 1 # 组播信息发送间隔,俩个节点必须配置一致,默认1sauthentication {auth_type PASSauth_pass 123456}virtual_ipaddress {192.168.163.140 ## 虚拟ip,可以指定多个}# 关联 Nginx 检查脚本track_script {chk_nginx}
}

副vim /etc/keepalived/keepalived.conf

global_defs {router_id LVS_DEVEL
}# 添加 Nginx 健康检查脚本配置
vrrp_script chk_nginx {script "/etc/keepalived/check_nginx.sh"interval 2   # 每2秒检查一次weight -20   # 如果脚本返回非0,优先级降低20(确保备节点接管)fall 2       # 连续2次失败才认为故障rise 1       # 1次成功就认为恢复
}vrrp_instance VI_1 {state BACKUP #从节点interface ens33 ## 绑定虚拟IP的网络接口(网卡),与本机IP地址所在的网络接口相同(我这里是eth0)virtual_router_id 140 ## 虚拟路由ID号(主备节点一定要相同)priority 95mcast_src_ip 192.168.163.135 ## 本机ip地址advert_int 1 # 组播信息发送间隔,俩个节点必须配置一致,默认1sauthentication {auth_type PASSauth_pass 123456}virtual_ipaddress {192.168.163.140 ## 虚拟ip,可以指定多个}# 关联 Nginx 检查脚本track_script {chk_nginx}
}

配置好重启keepalived

systemctl restart keepalived  
检测命令:
ip addr    
测试方法:停掉nginx/直接stop keepalived

4、同理

mysql、k8s等也可基于如此实现高可用

http://www.lryc.cn/news/572408.html

相关文章:

  • mongodb单节点改副本集模式
  • Python 开发环境全栈隔离架构:从 Anaconda 到 PyCharm 的四级防护体系
  • NetworkManager介绍与用法
  • 【单片机】51单片机练习代码
  • GRBL_UNO R3编译下载
  • Spring Boot 虚拟线程 vs WebFlux:谁更胜一筹?
  • Spring-创建第一个SpringBoot项目
  • apisix-使用hmac-auth插件进行接口签名身份验证\apisix consumer
  • SpringBoot项目启动时自动加载数据到Redis的完整实现方案,用于存储字典,定时任务,登录用户等
  • Spring @Autowired 依赖注入全解析
  • 语音情感识别:CNN-LSTM 和注意力增强 CNN-LSTM 模型的比较分析
  • Hive优化详细讲解
  • Redis 的优势有哪些,它是CP 还是 AP?CAP 理论又是什么?
  • C#的泛型和匿名类型
  • Ubuntu最新版本(Ubuntu22.04LTS)安装nfs服务器
  • Java八股文——计算机网络「传输层篇」
  • CppCon 2017 学习:Everything You Ever Wanted to Know about DLLs
  • CppCon 2017 学习:dynamic_cast from scratch
  • 【AJAX 实战】图书管理系统上 渲染图书列表+新增图书+删除图书
  • windows系统JDK1.8 与JDK 17切换
  • css3 文本效果(text-shadow、text-overflow、word-wrap、word-break)文本阴影、文本换行、文本溢出并隐藏显示省略号
  • 数据结构 6(算法)
  • CMake实践:指定gcc版本编译和交叉编译
  • 华为OD机试-最佳植树距离-二分(JAVA 2025A卷)
  • DeserializationViewer使用说明
  • Java并发编程实战 Day 29:大数据处理的并行计算模型
  • Arduino Nano 33 BLE Sense Rev 2开发板使用指南之【环境搭建 / 点灯】
  • FPGA基础 -- Verilog 命名事件
  • React 19中如何向Vue那样自定义状态和方法暴露给父组件。
  • 什么是Spark