centos环境下nginx高可用集群的搭建指南

 更新时间:2022年07月20日 09:59:19   作者:程可爱  
为了防止Nginx单点故障造成服务器瘫痪,本文介绍了Nginx实现高可用集群构建,下面这篇文章主要给大家介绍了关于centos环境下nginx高可用集群的搭建指南,文中通过实例代码介绍的非常详细,需要的朋友可以参考下

1.概述

nginx单机部署时,一旦宕机就会导致整个服务的不可用,导致雪崩式效应。集群式部署是解决单点式雪崩效应的有效方案,本文将在centos环境下,结合Keepalived搭建高可用的nginx集群。

2.CentOS中nginx集群搭建

2.1 集群架构图

当客户端请求服务器时,若利用nginx作为代理,则会首先访问nginx服务器,再通过nginx服务器转发到对应的服务器上。上述架构图的原理是:nginx-01和nginx-02是两台nginx服务器,其中nginx-01作为主服务器,通过keepalived与nginx-02形成一个小集群,同时还可以与nginx-03、nginx-04…nginx-n等多台服务器构成集群。当nginx-01因为某些原因宕机而停止服务时,其它nginx服务器会选举一个进行替代,使整个服务保持正常的运行。

2.2 Keepalived

Keepalived是一款基于vrrp协议的高可用集群软件,通过虚拟IP(VIP)对外提供服务,能够实时监控集群中服务器的运行状态并自动进行故障隔离,这些服务器都启动着相同的服务,当主服务器发生故障时,会自动将虚拟IP漂移到备份服务器,从而实现业务高可用。

2.3 集群搭建准备

1.需要两台nginx服务器

2.需要keepalived

3.需要虚拟ip

2.4 集群搭建

2.4.1 安装keepalived

分别在了两台虚拟机上,利用yum指令安装keepalived,指令如下:

yum install keepalived

可以利用下述指令确认是否安装成功,成功的话则会显示版本号,具体如下:

rpm -q -a keepalived 

若非特别指定安装目录,则在centos的安装路径如下:

/etc/keepalived

2.4.2 配置keepalived.conf

由于是主从配置,在主服务器中,找到keepalived.conf的文件,进行替换,该文件存储于/etc/keepalived路径下,找到后替换为如下内容:

global_defs {
	notification_email {
	  acassen@firewall.loc
	  failover@firewall.loc
	  sysadmin@firewall.loc
	}
	notification_email_from Alexandre.Cassen@firewall.loc
	smtp_ server 192.168.200.129
	smtp_connect_timeout 30
	router_id LVS_DEVEL	# LVS_DEVEL这字段在/etc/hosts文件中看;通过它访问到主机
}

vrrp_script chk_http_ port {
	script "/usr/local/src/nginx_check.sh"
	interval 2   # (检测脚本执行的间隔)2s
	weight 2  #权重,如果这个脚本检测为真,服务器权重+2
}

vrrp_instance VI_1 {
	state MASTER   # 备份服务器上将MASTER 改为BACKUP
	interface ens33 #网卡名称,可查看对应服务器的网卡
	virtual_router_id 51 # 主、备机的virtual_router_id必须相同
	priority 100   #主、备机取不同的优先级,主机值较大,备份机值较小
	advert_int 1	#每隔1s发送一次心跳
	authentication {	# 校验方式, 类型是密码,密码1111
        auth type PASS
        auth pass 1111
    }
	virtual_ipaddress { # 虛拟ip
		192.168.200.50 // VRRP H虛拟ip地址
	}
}

备份服务器的keepalived.conf替换为:

global_defs {
	notification_email {
	  acassen@firewall.loc
	  failover@firewall.loc
	  sysadmin@firewall.loc
	}
	notification_email_from Alexandre.Cassen@firewall.loc
	smtp_ server 192.168.200.129
	smtp_connect_timeout 30
	router_id LVS_DEVEL	# LVS_DEVEL这字段在/etc/hosts文件中看;通过它访问到主机
}

vrrp_script chk_http_ port {
	script "/usr/local/src/nginx_check.sh"
	interval 2   # (检测脚本执行的间隔)2s
	weight 2  #权重,如果这个脚本检测为真,服务器权重+2
}

vrrp_instance VI_1 {
	state MASTER   # 备份服务器上将MASTER 改为BACKUP
	interface ens33 #网卡名称,可查看对应服务器的网卡
	virtual_router_id 51 # 主、备机的virtual_router_id必须相同
	priority 10   #主、备机取不同的优先级,主机值较大,备份机值较小
	advert_int 1	#每隔1s发送一次心跳
	authentication {	# 校验方式, 类型是密码,密码1111
        auth type PASS
        auth pass 1111
    }
	virtual_ipaddress { # 虛拟ip
		192.168.200.50 // VRRP H虛拟ip地址
	}
}

2.4.3 编写nginx监测脚本

文件保存为bash类型,命名为:nginx_check.sh,也可以自定义文件名称,脚本内容如下:

#! /bin/bash
A=`ps -C nginx -no-header | wc - 1`
if [ $A -eq 0];then
	/usr/local/nginx/sbin/nginx
	sleep 2
	if [`ps -C nginx --no-header| wc -1` -eq 0 ];then
		killall keepalived
	fi
fi

脚本可根据喜好来自定义文件夹存放,我这里存放于/usr/local/src/nginx_check.sh,注意一点的是,脚本存放的路径必须与keepalived.conf中配置的脚本文件路径一致。脚本路径更改,则keepalived.conf中的路径也要修改。

2.4.4 启动keepalived

分别在两台服务器上执行如下指令:

systemctl start keepalived.service

查看keepalived进程是否运行,

ps -ef|grep keepalived

若运行成功,则会出现以下界面:

2.4.5 启动nginx

在主服务器和从服务器上,分别利用nginx启动命令启动nginx服务,在nginx安装目录下执行如下指令:

./nginx

2.4.6 测试

1测试方案如下

(1)关闭主服务器上的nginx

在nginx安装目录下执行如下指令:

./nginx -s stop

(2)访问虚拟ip

在外部浏览器输入:

192.168.200.50:80

若能正常弹出nginx欢迎页面,则表明集群搭建成功,主服务器nginx宕机后,从服务器会代替服务。

3.小结

1.本文利用两台服务器模拟nginx集群状态,当nginx master宕机后,从服务器会代替服务;

2.模拟集群关键三要素:keepalived、监测脚本、虚拟ip;

3.在某些情况下,需要为脚本添加可执行权限,指令如下:

chmod +x /usr/local/src/nginx_check.sh #脚本地址根据实际情况而定

4.参考文献

1.https://www.bilibili.com/video/BV1zJ411w7SV?t=85&p=1

2.https://juejin.cn/post/6844903956192182285

3.https://juejin.cn/post/6844903929738854413

4.https://juejin.cn/post/6844903585449246733

总结

到此这篇关于centos环境下nginx高可用集群搭建的文章就介绍到这了,更多相关nginx高可用集群搭建内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Nginx与Tomcat实现动静态分离和负载均衡

    Nginx与Tomcat实现动静态分离和负载均衡

    本篇文章主要介绍了Nginx与Tomcat实现动静态分离和负载均衡,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2016-10-10
  • Nginx Linux安装部署详细教程

    Nginx Linux安装部署详细教程

    这篇文章主要介绍了Nginx Linux安装部署详细教程,本文通过图文实例代码相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • 实例详解SpringBoot+nginx实现资源上传功能

    实例详解SpringBoot+nginx实现资源上传功能

    这篇文章主要介绍了SpringBoot+nginx实现资源上传功能,由于小编最近在使用nginx放置静态资源问题,遇到很多干货,特此分享到脚本之家平台,供大家参考,需要的朋友可以参考下
    2019-10-10
  • 通过Nginx定义Header头信息的实现步骤

    通过Nginx定义Header头信息的实现步骤

    本文主要介绍了通过Nginx定义Header头信息的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • Keepalived+Nginx+Tomcat 实现高可用Web集群的示例代码

    Keepalived+Nginx+Tomcat 实现高可用Web集群的示例代码

    这篇文章主要介绍了Keepalived+Nginx+Tomcat 实现高可用Web集群的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • Nginx中防止SQL注入攻击的相关配置介绍

    Nginx中防止SQL注入攻击的相关配置介绍

    这篇文章主要介绍了Nginx中防止SQL注入攻击的相关配置介绍,文中提到的基本思路为将过滤的情况用rewrite重订向到404页面,需要的朋友可以参考下
    2016-01-01
  • Nginx实现正向代理实例

    Nginx实现正向代理实例

    这篇文章主要介绍了Nginx实现正向代理实例,正向代理的作用在于正向代理隐藏了用户,用户的请求被代理服务器接收代替,到了服务器,服务器并不知道用户是谁,需要的朋友可以参考下
    2023-08-08
  • nginx rtmp模块编译 arm版本的问题

    nginx rtmp模块编译 arm版本的问题

    这篇文章主要介绍了nginx rtmp模块编译 arm版本的问题,pcre库和libz库都不用单独编译,在编译nginx时添加模块时一起编译,需要的朋友可以参考下
    2021-12-12
  • 讨论nginx location 顺序问题

    讨论nginx location 顺序问题

    在有一次配置时发现,请求 uri 明明是符合了前缀匹配 ^~ 规则,但 nginx 却没有使用,这让我对上述结论产生了疑惑。后续通过调研、实践后发现,上述结论可以说对,但也不对,是不是更疑惑了?没关系,看完这篇文章你就知道我为什么会这样说了
    2022-05-05
  • nginx:413 Request Entity Too Large的处理办法--修改 PHP上传文件大小

    nginx:413 Request Entity Too Large的处理办法--修改 PHP上传文件大小

    在用 phpMyAdmin 进行 sql 数据库导入的时候,经常需要上传比较大的 sql 数据文件,而这时会常碰见 nginx报错:413 Request Entity Too Large。解决此问题,根据上传数据文件的大小进行修改处理
    2014-06-06

最新评论