首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >生产环境:Nginx高可用方案

生产环境:Nginx高可用方案

作者头像
猿哥
发布于 2019-06-17 10:54:54
发布于 2019-06-17 10:54:54
71500
代码可运行
举报
文章被收录于专栏:Web技术布道师Web技术布道师
运行总次数:0
代码可运行
准备工作:

192.168.16.128

192.168.16.129

两条虚拟机。安装好 Nginx

安装Nginx

更新 yum 源文件:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
rpm -ivh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

安装Nginx:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
yum -y install  nginx

操作命令:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
systemctl start nginx; #启动Nginx
systemctl stop nginx; #停止Nginx

什么是高可用?

高可用HA(High Availability)是分布式系统架构设计中必须考虑的因素之一,它通常是指,通过设计减少系统不能提供服务的时间。如果一个系统能够一直提供服务,那么这个可用性则是百分之百,但是天有不测风云。所以我们只能尽可能的去减少服务的故障。

解决的问题?

在生产环境上很多时候是以 Nginx 做反向代理对外提供服务,但是一天Nginx难免遇见故障,如:服务器宕机。当 Nginx 宕机那么所有对外提供的接口都将导致无法访问。

虽然我们无法保证服务器百分之百可用,但是也得想办法避免这种悲剧,今天我们使用 keepalived 来实现 Nginx

的高可用。

双机热备方案

这种方案是国内企业中最为普遍的一种高可用方案,双机热备其实就是指一台服务器在提供服务,另一台为某服务的备用状态,当一台服务器不可用另外一台就会顶替上去。

keepalived是什么?

Keepalived 软件起初是专为 LVS 负载均衡软件设计的,用来管理并监控LVS集群系统中各个服务节点的状态,后来又加入了可以实现高可用的 VRRP (Virtual Router Redundancy Protocol ,虚拟路由器冗余协议) 功能。因此, Keepalived 除了能够管理LVS软件外,还可以作为其他服务(例如:Nginx、Haproxy、MySQL等) 的高可用解决方案软件

故障转移机制

Keepalived 高可用服务之间的故障切换转移,是通过 VRRP 来实现的。

Keepalived 服务正常工作时,主 Master 节点会不断地向备节点发送(多播的方式)心跳消息,用以告诉备 Backup 节点自己还活着,当主 Master 节点发生故障时,就无法发送心跳消息,备节点也就因此无法继续检测到来自主 Master 节点的心跳了,于是调用自身的接管程序,接管主Master节点的 IP资源及服务。而当主 Master节点恢复时,备Backup节点又会释放主节点故障时自身接管的IP资源及服务,恢复到原来的备用角色。

实现过程

安装keepalived

yum 方式直接安装即可,该方式会自动安装依赖:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
yum -y install keepalived
修改主机(192.168.16.128)keepalived配置文件

yum 方式安装的会生产配置文件在 /etc/keepalived 下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
vi keepalived.conf

keepalived.conf:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#检测脚本
vrrp_script chk_http_port {
    script "/usr/local/src/check_nginx_pid.sh" #心跳执行的脚本,检测nginx是否启动
    interval 2                          #(检测脚本执行的间隔,单位是秒)
    weight 2                            #权重
}
#vrrp 实例定义部分
vrrp_instance VI_1 {
    state MASTER            # 指定keepalived的角色,MASTER为主,BACKUP为备
    interface ens33         # 当前进行vrrp通讯的网络接口卡(当前centos的网卡) 用ifconfig查看你具体的网卡
    virtual_router_id 66    # 虚拟路由编号,主从要一直
    priority 100            # 优先级,数值越大,获取处理请求的优先级越高
    advert_int 1            # 检查间隔,默认为1s(vrrp组播周期秒数)
    #授权访问
    authentication {
        auth_type PASS #设置验证类型和密码,MASTERBACKUP必须使用相同的密码才能正常通信
        auth_pass 1111
    }
    track_script {
        chk_http_port            #(调用检测脚本)
    }
    virtual_ipaddress {
        192.168.16.130            # 定义虚拟ip(VIP),可多设,每行一个
    }
}

virtual_ipaddress 里面可以配置vip,在线上通过vip来访问服务。

interface 需要根据服务器网卡进行设置通常查看方式 ip addr

authentication 配置授权访问后备机也需要相同配置

修改备机(192.168.16.129)keepalived配置文件

keepalived.conf:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#检测脚本
vrrp_script chk_http_port {
    script "/usr/local/src/check_nginx_pid.sh" #心跳执行的脚本,检测nginx是否启动
    interval 2                          #(检测脚本执行的间隔)
    weight 2                            #权重
}
#vrrp 实例定义部分
vrrp_instance VI_1 {
    state BACKUP                        # 指定keepalived的角色,MASTER为主,BACKUP为备
    interface ens33                      # 当前进行vrrp通讯的网络接口卡(当前centos的网卡) 用ifconfig查看你具体的网卡
    virtual_router_id 66                # 虚拟路由编号,主从要一直
    priority 99                         # 优先级,数值越大,获取处理请求的优先级越高
    advert_int 1                        # 检查间隔,默认为1s(vrrp组播周期秒数)
    #授权访问
    authentication {
        auth_type PASS #设置验证类型和密码,MASTERBACKUP必须使用相同的密码才能正常通信
        auth_pass 1111
    }
    track_script {
        chk_http_port                   #(调用检测脚本)
    }
    virtual_ipaddress {
        192.168.16.130                   # 定义虚拟ip(VIP),可多设,每行一个
    }
}
检测脚本:
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#!/bin/bash
#检测nginx是否启动了
A=`ps -C nginx --no-header |wc -l`        
if [ $A -eq 0 ];then    #如果nginx没有启动就启动nginx                        
      systemctl start nginx                #重启nginx
      if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then    #nginx重启失败,则停掉keepalived服务,进行VIP转移
              killall keepalived                    
      fi
fi

脚本授权: chmod 775 check_nginx_pid.sh

说明:脚本必须通过授权,不然没权限访问啊,在这里我们两条服务器执行、 VIP(virtual_ipaddress:192.168.16.130) ,我们在生产环境是直接通过vip来访问服务。

模拟 nginx 故障:

修改两个服务器默认访问的 Nginxhtml 页面作为区别。

首先访问 192.168.16.130 ,通过 vip 进行访问,页面显示 192.168.16.128 ;说明当前是主服务器提供的服务。

这个时候 192.168.16.128 主服务器执行命令:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
systemctl stop nginx; #停止nginx

再次访问 vip(192.168.16.130) 发现这个时候页面显示的还是: 192.168.16.128 ,这是脚本里面自动重启。

现在直接将 192.168.16.128 服务器关闭,在此访问 vip(192.168.16.130) 现在发现页面显示192.168.16.129 这个时候 keepalived 就自动故障转移了,一套企业级生产环境的高可用方案就搭建好了。

keepalived 中还有许多功能比如:邮箱提醒啊等等,就不操作了,可以去官网看看文档。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-06-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 PHP技术大全 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Nginx 挂了怎么办?怎么实现高可用?
高可用HA(High Availability)是分布式系统架构设计中必须考虑的因素之一,它通常是指,通过设计减少系统不能提供服务的时间。
杰哥的IT之旅
2021/09/03
9360
Nginx+Keepalived实现服务的高可用
Keepalived软件起初是专为LVS负载均衡软件设计的,用来管理并监控LVS集群系统中各个服务节点的状态,后来又加入了可以实现高可用的VRRP功能。因此,keepalived除了能够管理LVS软件外,还可以作为其他服务的高可用解决方案软件。
胡齐
2019/09/25
9680
Nginx+Keepalived实现服务的高可用
Keepalived实现对web服务的高可用
Keepalived is a routing software written in C.
用户6641876
2020/03/11
2.1K0
Keepalived实现对web服务的高可用
Nginx高可用的配置-Keepalived
单个Nginx负载均衡整个系统,如果nginx挂了,那么整个系统都将瘫痪,这时我们就需要保证及时1个Nginx挂了,整个系统也是可用的。
用户4919348
2020/06/22
1.1K0
Linux巩固记录(9) keepalived+nginx搭建高可用负载分发环境
web 192.168.2.100 再iis上启动了9011/9012/9013三个端口的web应用
肖哥哥
2018/08/02
4660
Linux巩固记录(9) keepalived+nginx搭建高可用负载分发环境
配置Keepalived+Nginx高可用
Keepalived 软件起初是专为LVS负载均衡软件设计的,用来管理并监控LVS集群系统中各个服务节点的状态,后来又加入了可以实现高可用的VRRP功能。VRRP是Virtual Router RedundancyProtocol(虚拟路由器冗余协议)的缩写,VRRP出现的目的就是为了解决静态路由单点故障问题的,它能够保证当个别节点宕机时,整个网络可以不间断地运行。
陳斯托洛夫斯記
2024/08/07
4140
Nginx(六):配置nginx高可用集群
我们知道在我们使用nginx代理多态tomcat服务器时,如果某台tomcat服务器发生宕机,那么nginx的分配机制可以自动将其剔除。但是如果发生了nginx的宕机状况,又该如何解决呢。
栗筝i
2022/12/01
3.9K0
Nginx(六):配置nginx高可用集群
使用Haproxy和Keepalived实现高可用的负载均衡
尽管HAProxy非常稳定,但仍然无法规避操作系统故障、主机硬件故障、网络故障甚至断电带来的风险。所以必须对HAProxy实施高可用方案。
砒霜拌辣椒
2023/08/23
9321
使用Haproxy和Keepalived实现高可用的负载均衡
nginx高可用方案及部署文档
Nginx是一款非常流行的高性能Web服务器,也可以作为负载均衡器来提供高可用性。在本文中,我将介绍一种基于Nginx的高可用方案,同时提供一份详细的部署文档。
堕落飞鸟
2023/03/27
1.6K0
Keepalived高可用集群(双主)
Keepalived软件起初是专门为LVS负载均衡软件设计的用来管理并监控LVS集群系统中各个服务节点的状态,后来又加入了可以实现高可用的VRRP功能。因此,Keepalived除了能够管理LVS软件外,还可以作为其他服务的高可用解决方案软件。
jwangkun
2021/12/23
1K0
Keepalived高可用集群(双主)
Keepalived高可用介绍与配置详解
Keepalived 软件起初是专为LVS负载均衡软件设计的,用来管理并监控LVS集群系统中各个服务节点的状态,后来又加入了可以实现高可用的VRRP功能。因此,Keepalived除了能够管理LVS软件外,还可以作为其他服务(例如:Nginx、Haproxy、MySQL等)的高可用解决方案软件。
星哥玩云
2022/07/26
3930
集群高可用代理实践分享
在 Kubernetes 集群的 高可用拓扑选项[1] 中,介绍了集群高可用的两个方案:
gopher云原生
2022/06/08
9610
集群高可用代理实践分享
Nginx + keepalived 实现高可用 + 防盗链 + 动静分离,写得太好了!
点击关注公众号,Java干货及时送达 作者:小不点啊 来源:www.cnblogs.com/leeSmall/p/9356535.html 一、Nginx Rewrite 规则 1. Nginx rewrite规则 Rewrite规则含义就是某个URL重写成特定的URL(类似于Redirect),从某种意义上说为了美观或者对搜索引擎友好,提高收录量及排名等。 语法: rewrite <regex> <replacement> [flag] 关键字 正则 替代内容 flag标记 Rewrite规则的fla
Java技术栈
2022/08/25
7800
Nginx + keepalived 实现高可用 + 防盗链 + 动静分离,写得太好了!
高可用篇之Keepalived (HAProxy+keepalived 搭建高可用负载均衡集群)
Keepalived是Linux下一个轻量级别的高可用解决方案。健康检查和失败切换是keepalived的两大核心功能。所谓的健康检查,就是采用tcp三次握手,icmp请求,http请求,udp echo请求等方式对负载均衡器后面的实际的服务器(通常是承载真实业务的服务器)进行健康状态检测;而失败切换主要是应用于配置了主备模式的负载均衡器,利用VRRP维持主备负载均衡器的心跳,当主负载均衡器出现问题时,由备负载均衡器承载对应的业务,从而在最大限度上减少流量损失,并提供服务的稳定性。 与HeartBeat相比,Keepalived主要是通过虚拟路由冗余来实现高可用功能,虽然它没有HeartBeat功能强大,但是Keepalived部署和使用非常的简单,所有配置只需要一个配置文件即可以完成。配置文件名:/etc/keepalived/keepalived.conf
小土豆Yuki
2020/06/15
17.7K1
nginx实现请求的负载均衡 + keepalived实现nginx的高可用
  使用集群是网站解决高并发、海量数据问题的常用手段。当一台服务器的处理能力、存储空间不足时,不要企图去换更强大的服务器,对大型网站而言,不管多么强大的服务器,都满足不了网站持续增长的业务需求。这种情况下,更恰当的做法是增加一台服务器分担原有服务器的访问及存储压力。通过负载均衡调度服务器,将来自浏览器的访问请求分发到应用服务器集群中的任何一台服务器上,如果有更多的用户,就在集群中加入更多的应用服务器,使应用服务器的负载压力不再成为整个网站的瓶颈。
青石路
2018/09/10
1.4K0
nginx实现请求的负载均衡 + keepalived实现nginx的高可用
Nginx+Keepalived(双机热备)搭建高可用负载均衡环境(HA)
基于 Nginx+Tomcat+Redis负载均衡Session共享来实现后续的功能 个人微信小程序。是关于人工智能的。应用是百度大脑 和 腾讯优图的人脸识别 有问题加QQ:783021975 验证问
小帅丶
2018/03/12
1.4K0
Nginx+Keepalived(双机热备)搭建高可用负载均衡环境(HA)
keepalived实现服务高可用
惨绿少年
2017/12/27
2.8K0
keepalived实现服务高可用
nginx+keepalived搭建高可用负载均衡
如果一台Nginx服务器宕机了,那么整个网站就会挂掉,所以要实现Nginx的高可用,一台挂掉还会有另一台顶上去,从而保证网站可持续的提供服务。
菲宇
2022/12/21
7060
nginx+keepalived搭建高可用负载均衡
Nginx+Keepalived实现简单的服务高可用
但是,作为互联网项目,纯2C的话必然需要做高可用,不仅后端的Server有N个,Nginx同样需要有N个,一主N备,当有一个服务器挂掉的时候,服务能瞬间切换到其他服务器,大概是这样的
小尘哥
2019/01/02
1.2K0
Nginx系列(7) —— Nginx配置高可用集群
CAP原则又称CAP定理,指的是在一个分布式系统中,一致性(Consistency)、可用性(Availability)、分区容错性(Partition tolerance)。CAP 原则指的是,这三个要素最多只能同时实现两点,不可能三者兼顾。
求和小熊猫
2020/11/25
1.7K0
相关推荐
Nginx 挂了怎么办?怎么实现高可用?
更多 >
交个朋友
加入腾讯云官网粉丝站
蹲全网底价单品 享第一手活动信息
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档