当前位置: 首页 > 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.lqws.cn/news/443809.html

相关文章:

  • TensorFlow+CNN垃圾分类深度学习全流程实战教程
  • 【目标检测】IOU的概念与Python实例解析
  • Qt蓝图式技能编辑器状态机模块设计与实现
  • Datawhale 网络爬虫技术入门第2次笔记
  • CD45.【C++ Dev】STL库的list的使用
  • redis02
  • 什么是Spark
  • 【Dify 沙箱网络问题排查与解决】
  • 亚马逊云科技中国峰会召开 解码Agentic AI时代企业加速创新路径
  • Codeforces Round 1032 (Div. 3)
  • Netty实战:从核心组件到多协议实现(超详细注释,udp,tcp,websocket,http完整demo)
  • (17)-java+ selenium->自动化测试-元素定位大法之By css上
  • openKylin高校沙龙 | 走进成都高校,推动开源技术交流与人才培养
  • ollama优化小贴士
  • flex布局 项目属性
  • 5_STM32F103ZET6系统启动过程
  • windows11 + ubuntu2204双系统+ros2 humble安装
  • IT小白到高手:HCIA、HCIP、HCIE认证攻略
  • (哈希)128. 最长连续序列
  • 嵌入式Web服务实战:OpenWRT+内网穿透实现物联网设备公网访问全攻略
  • ‘conda‘ 不是内部或外部命令,也不是可运行的程序或批处理文件?
  • FPGA基础 -- Verilog 系统任务与系统函数
  • 嘉立创EDA学习笔记4
  • 集合的处理:JDK和Guava孰强孰弱?
  • C#建立与数据库连接(版本问题的解决方案)踩坑总结
  • docker 目录更改,必须做数据迁移才能启动
  • 输入url之后发生了什么
  • Python-循环结构解析
  • Windows 10开始菜单优化方案,如何实现Win7风格开始菜单的还原
  • oracle通过dblink 连接pg数据库