Nginx+keeplived高可用

news2025/7/31 2:04:00

目录

一、环境准备

1、准备3台centos服务器

2、安装软件

二、keepalived配置

三、nginx进程监视脚本


一、环境准备

1、准备3台centos服务器

服务器名主机名IPVIP
Nginx代理服务器proxy1192.168.1.10192.168.1.100
Nginx代理服务器proxy2192.168.1.20
web网站服务器web1192.168.1.30/

                 

 实验效果:实验keepalived实现对Nginx代理服务器的高可用,防止一台Nginx出现宕机导致网站无法访问的情况。

2、安装软件

(1)Nginx安装

三台服务器都安装Nginx,proxy1和proxy2的Nginx负责提供Nginx代理,web1的Nginx负责提供网页服务:

安装步骤:Nginx安装、配置与概述_桂安俊@kylinOS的博客-CSDN博客

(2)、keepalived安装

#proxy1和proxy2安装keepalived
yum install keepalived -y

二、keepalived配置

1、proxy1配置:

vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived

global_defs {
   router_id test111    #router_id后面名称自定义
}

vrrp_instance nginx_test {
    state MASTER
    interface ens33     #对应实际网卡名
    virtual_router_id 51
    priority 100    #优先级,主备竞选的时候,优先级高的竞选master,数越大,优先级越高
    advert_int 1
    authentication {   #同一组keepalived认证
        auth_type PASS
        auth_pass 1111    
    }
    virtual_ipaddress {    #虚拟ip
        192.168.1.100
    }
}

2、proxy2配置:

vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived

global_defs {
   router_id test112    #router_id后面名称自定义,和proxy1不一样即可
}

vrrp_instance nginx_test {
    state BACKUP        #proxy1为主,那这边就为备
    interface ens33     #对应实际网卡名
    virtual_router_id 51  # 虚拟路由的ID号,两个节点设置必须一样,可选IP最后一段使用,相同的VRID为一个组,他将决定多播的MAC地址
    priority 50    #备机优先级改低一点
    advert_int 1   #组播信息发送时间间隔,两个节点必须设置一样,默认为1秒
    authentication {   #设置验证信息,两个节点必须一致
        auth_type PASS
        auth_pass 1111     #要和proxy1对上  
    }
    virtual_ipaddress {    #虚拟IP,两个节点设置必须一样。可以设置多个,一行写一个
        192.168.1.100
    }
}

重启proxy1和proxy2的keepalived服务

systemctl restart keepalived

此时虚拟IP在proxy1上:

 测试keepalived:将proxy1关机,虚拟IP会漂到proxy2上。

三、nginx进程监视脚本

keepalived的检测机制就是检查keepalived进程,当keepalived进程异常,才会进行vip漂移。如果keepalived正常,但是nginx故障,那就会带来vip不漂移导致网站无法访问的问题,这时可以自己写一个脚本去检查nginx状态,如果异常,则kill掉keepalived实现ip漂移,或者重新启动nginx。下面以keepalived重新启动nginx为例:

keepalived节点服务器配置都要改:

vim  /etc/keepalived/check_nginx.sh
#!/bin/bash
A=`ps -C nginx --no-header | wc -l`
if [ $A -eq 0 ];then
	/usr/local/nginx/sbin/nginx
	if [ `ps -c nginx --no-header | wc -l` -eq 0 ];then
		exit 1
	else
		exit 0
	fi
else
	exit 0
fi
chmod +x /etc/keepalived/check_nginx.sh   #给执行权限

然后将check_nginx.sh监测脚本加入keepalived.conf配置文件中调用:

vim /etc/keepalived/keepalived.conf

keepalived节点都要加(红色字体部分),下面以proxy1的keepalived配置为例:

! Configuration File for keepalived

global_defs {
   router_id test111 
}

vrrp_script check_nginx {           #定义一个策略,策略名为"check_nginx"
    script "/etc/keepalived/check_nginx.sh"  #指定脚本路径
    interval  1     #检测时间间隔1秒钟
    weight -20      #如果发现nginx启动失败了,将当前的机器的priority优先级减20
}

vrrp_instance nginx_test {
    state MASTER
    interface ens33 
    virtual_router_id 51
    priority 100    
    advert_int 1     
    authentication {  
        auth_type PASS
        auth_pass 1111    
    }
    virtual_ipaddress {   
        192.168.1.100
    }

    track_script {    #nginx存活状态检测脚本
          check_nginx
    }

}

测试:手动关闭一台服务器nginx:

/usr/local/nginx/sbin/nginx -s stop

会发现nginx被keepalived检测脚本自动启动。

 【附】完整keepalived调用check_nginx.sh监测配置文件:

proxy1 keepalived.conf配置内容:

! Configuration File for keepalived

global_defs {
   router_id test111 
}

vrrp_script check_nginx {
    script "/etc/keepalived/check_nginx.sh"  
    interval  1     
    weight -20      
}

vrrp_instance nginx_test {
    state MASTER
    interface ens33 
    virtual_router_id 51
    priority 100    
    advert_int 1
    authentication {  
        auth_type PASS
        auth_pass 1111    
    }
    virtual_ipaddress {   
        192.168.1.100
    }

    track_script {
        check_nginx
    }
}

proxy2 keepalived.conf配置内容:

! Configuration File for keepalived

global_defs {
   router_id test112 
}

vrrp_script check_nginx {
    script "/etc/keepalived/check_nginx.sh"  
    interval  1     
    weight -20      
}

vrrp_instance nginx_test {
    state MASTER
    interface ens33 
    virtual_router_id 51
    priority 50    
    advert_int 1
    authentication {  
        auth_type PASS
        auth_pass 1111    
    }
    virtual_ipaddress {   
        192.168.1.100
    } 

    track_script {
        check_nginx
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/16212.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

TikTok 的 TAP好货分销服务商招募啦,最新入驻政策速来了解

众所周知,以抖音快手平台为主的内容电商对于国内来说已经司空见惯,内卷到极致,但是对于国外来说还是一个比较新奇的领域。 而海外版抖音 TikTok就成功实现了内容电商的出海,将电商直播带出国门,面向全世界。为了完善T…

【16-配置中心之Nacos的基本使用Nacos服务之命令空间、Nacos服务之配置组、Nacos服务之配置拆分】

一.知识回顾 【0.三高商城系统的专题专栏都帮你整理好了,请点击这里!】 【1-系统架构演进过程】 【2-微服务系统架构需求】 【3-高性能、高并发、高可用的三高商城系统项目介绍】 【4-Linux云服务器上安装Docker】 【5-Docker安装部署MySQL和Redis服务】…

SpringBoot与mockito那点事

题目起的很像那么回事,但是这篇博客本身写的很简单。 我不想写说一堆概念,然后阐释各种概念是什么意思。我喜欢的是直接从例子出发。 package com.example.demo.controller;import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; impo…

操作系统的奋斗(一)

第1章 计算机系统概述1.1操作系统的基本概念1.1.1操作系统的概念1.1.2操作系统的特征(1)并发(2)共享(3)虚拟(4)异步1.1.3操作系统的目标和功能1.2操作系统发展史(1&#…

微信公众号开发:网页授权

一、背景介绍 微信公众号网页授权,目的就是获取用户相关信息,实现自己的业务逻辑,最终于会得到的信息如下表格,本文对应的任务获取到openid即可满足业务需求,本文内容包括环境、操作步骤及相关内容比较详细&#xff0…

3D可视化工厂是如何实现的?

3D可视化工厂是数字孪生的一种方式,是基于智慧工厂现实场景进行虚拟的可视化工厂。 在传统工作模式下,许多工厂仍然存在着数据孤岛、生产过程缺乏监控及工作效率低等问题。如何进行工厂数字化的集中管理,寻求全新的数据驱动型业务解决方案&am…

5.python 列表切片双冒号[: :]和[:,j]

列表切片1.[::]2.[ :,j]3. [::]操作高阶用法1.[::] 适用于Python中的list(也就是数组)&#xff0c;也适用于numpy科学结构(array等)。 使用方法[start: end : step ]&#xff0c;也就是[ 起始下标 : 终止下标 : 间隔距离 ] 切片范围是&#xff1a; start < x < end,注…

iOS 优雅的定义一些全局常量和函数

我们常常使用 #define 来定义一些宏&#xff0c;全局使用。但是可以采用一些更优雅的方式来实现。 方式一&#xff1a;使用 extern 使用场景&#xff1a;工程内多处用到同一个常量。开发中便与管理某一个模块的全局变量&#xff0c;通常创建一个模块的配置文件&#xff0c;里面…

Qt构建时遇到error LNK2019: 无法解析的外部符号 __imp__glAlphaFunc@8,

在我的印象中如果是遇到无法解析的外部命令&#xff0c;无非就是两种情况 头文件定义了方法没有实现lib库没加 因为我这次写的软件我不确定缺失什么库&#xff0c;所以就先检查方法是否未实现&#xff0c;发现方法都实现了&#xff0c;那就只能是lib库缺失的问题了&#xff0…

【机器学习并行计算】1 MapReduce

1 MapReduce 每个节点计算梯度&#xff0c;然后汇聚到一台机子上&#xff0c;再进行梯度下降。时间还需要考虑通信时间。 通信的方式有两种&#xff1a;共享内存和消息传递&#xff1b;在这里存在多机的情况都是消息传递的方式。 通信耗时 MapReduce 会有风险&#xff0c;因为每…

[附源码]java毕业设计农村电商平台

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Python编程从入门到实践 第九章:类 练习答案记录

Python编程从入门到实践 第九章&#xff1a;类 练习答案记录 练习题导航Python编程从入门到实践 第九章&#xff1a;类 练习答案记录9.1 创建和使用类9.1.1 创建Dog类9.1.2 根据类创建实例练习9-1 餐馆 &#xff1a; 创建一个名为Restaurant 的类&#xff0c; 其方法__init__()…

Android 进程间通信(IPC机制)精炼详解

今天主要对 Android 中的跨进程通信进行总结下&#xff0c;先梳理下里面的涉及的一些概念 进程与线程 进程&#xff1a; 系统中正在运行的一个应用程序&#xff0c;某个程序一旦运行就是一个进程&#xff0c;是资源分配的最小单位&#xff1b;线程&#xff1a; 程序执行的最小…

曙光云使用说明

平台链接 https://ac.sugon.com/ac/home/index.html 控制台界面 创建个人工作目录及上传文件。点击概览页面顶端的 E-Shell 菜单栏&#xff0c;进入所连主机的 Shell 终端。在用户目录下新建个人工作目录&#xff0c;如&#xff1a;mkdir ywj2 安装MiniConda&#xff08;推荐…

Ubuntu20.04 如何开启root账户登陆

环境&#xff1a; 电脑&#xff1a;戴尔7080 系统&#xff1a;Windows 10 专业版 64位 VMware 16.0 &#xff1a;Ubuntu20.04 问题描述&#xff1a; Ubuntu20.04 如何开启root账户登陆 解决方案&#xff1a; 1.以普通用户登录系统&#xff0c;创建root用户的密码 在终端…

Java代码审计——WebGoat XSS

目录 &#xff08;一&#xff09;XSS 常见触发位置 1&#xff0e;JSP 表达式 2&#xff0e;EL &#xff08;二&#xff09;反射型 XSS (三&#xff09; 存储型 XSS &#xff08;四&#xff09;XSS 漏洞修复 配置过滤器&#xff1a; &#xff08;一&#xff09;XSS 常见触发…

HTML期末作业课程设计期末大作业__电影长津湖介绍带视频(6页)

⛵ 源码获取 文末联系 ✈ Web前端开发技术 描述 网页设计题材&#xff0c;DIVCSS 布局制作,HTMLCSS网页设计期末课程大作业 | 摄影作品 | 影视设计网页 | 在线电影 | 视频音频元素 | HTML期末大学生网页设计作业&#xff0c;Web大学生网页 HTML&#xff1a;结构 CSS&#xff1…

uiautomator2的安装,使用,在浏览器中查看页面的信息,简单快捷的ui测试工具,app测试工具(一)

uiautomator2的安装&#xff0c;使用&#xff0c;简单快捷的ui测试工具&#xff0c;app测试工具 安装方法 命令行中输入 pip install uiautomator pip install weditor在andriod studio中启动一个模拟器 启动 python -m weditor即可在浏览器看到弹出的窗口&#xff0c;里面…

【滤波跟踪】基于不变扩展卡尔曼滤波器对装有惯性导航系统和全球定位系统IMU+GPS进行滤波跟踪附matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;修心和技术同步精进&#xff0c;matlab项目合作可私信。 &#x1f34e;个人主页&#xff1a;Matlab科研工作室 &#x1f34a;个人信条&#xff1a;格物致知。 更多Matlab仿真内容点击&#x1f447; 智能优化算法 …

核苷酸类化合物库 脂类化合物库参与细胞调控

核苷及核苷酸是机体内的一种重要的内源物质&#xff0c;参与细胞的多种生命进程&#xff0c;如 DNA 和 RNA 合成&#xff0c;信号转导及代谢等。核苷及核苷酸类似物是人工合成的&#xff0c;经过一定化学修饰的物质&#xff0c;可以模拟机体内核苷及核苷酸&#xff0c;参与细胞…