要实现nginx的高可用,需要实现备份机。

1.1. 什么是负载均衡高可用

nginx作为负载均衡器,所有请求都到了nginx,可见nginx处于非常重点的位置,如果nginx服务器宕机后端web服务将无法提供服务,影响严重。

为了屏蔽负载均衡服务器的宕机,需要建立一个备份机。主服务器和备份机上都运行高可用(High Availability)监控程序,通过传送诸如“I am alive”这样的信息来监控对方的运行状况。当备份机不能在一定的时间内收到这样的信息时,它就接管主服务器的服务IP并继续提供负载均衡服务;当备份管理器又从主管理器收到“I am alive”这样的信息时,它就释放服务IP地址,这样的主服务器就开始再次提供负载均衡服务。

1.2. keepalived+nginx实现主备

1.2.1. 什么是keepalived

keepalived是集群管理中保证集群高可用的一个服务软件,用来防止单点故障。

Keepalived的作用是检测web服务器的状态,如果有一台web服务器死机,或工作出现故障,Keepalived将检测到,并将有故障的web服务器从系统中剔除,当web服务器工作正常后Keepalived自动将web服务器加入到服务器群中,这些工作全部自动完成,不需要人工干涉,需要人工做的只是修复故障的web服务器。

1.2.2. keepalived工作原理

keepalived是以VRRP协议为实现基础的,VRRP全称Virtual Router Redundancy Protocol,即虚拟路由冗余协议。

虚拟路由冗余协议,可以认为是实现路由器高可用的协议,即将N台提供相同功能的路由器组成一个路由器组,这个组里面有一个master和多个backup,master上面有一个对外提供服务的vip(VIP = Virtual IP Address,虚拟IP地址,该路由器所在局域网内其他机器的默认路由为该vip),master会发组播,当backup收不到VRRP包时就认为master宕掉了,这时就需要根据VRRP的优先级来选举一个backup当master。这样的话就可以保证路由器的高可用了。

keepalived主要有三个模块,分别是core、check和VRRP。core模块为keepalived的核心,负责主进程的启动、维护以及全局配置文件的加载和解析。check负责健康检查,包括常见的各种检查方式。VRRP模块是来实现VRRP协议的。

1.2.3. keepalived+nginx实现主备过程

初始状态

什么是Nginx负载均衡高可用?看完这一篇就明白

主机宕机

什么是Nginx负载均衡高可用?看完这一篇就明白

主机恢复

什么是Nginx负载均衡高可用?看完这一篇就明白

高可用环境

两台nginx,一主一备:192.168.101.3和192.168.101.4

两台tomcat服务器:192.168.101.5、192.168.101.6

【凡本网注明来源非中国IDC圈的作品,均转载自其它媒体,目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。】

关注中国IDC圈官方微信:idc-quan 我们将定期推送IDC产业最新资讯

查看心情排行你看到此篇文章的感受是:


  • 支持

  • 高兴

  • 震惊

  • 愤怒

  • 无聊

  • 无奈

  • 谎言

  • 枪稿

  • 不解

  • 标题党
2020-03-02 17:39:00
整机柜服务器 科技抗疫背后的1100万台服务器算力
目前中国已经是全球第二大服务器市场,并且增长迅速。能够对服务器保持如此旺盛的需求,是因为中国正处于从信息社会向智能社会升级的关键时期,服务器所提供的计算力正在成 <详情>
2020-03-02 11:10:35
云资讯 抗击疫情,背后是1100万台服务器
2月19日,阿里云公众号发表了一篇文章,提到其华南地区规模最大的数据中心正在急速扩容。 <详情>
2020-02-27 12:28:51
整机柜服务器 服务器故障 微盟集团单日市值缩水11.19亿港元
受服务器出现故障影响,2月26日,商微信头部服务提供商微盟集团股价低开低走,尾盘再度跳水。 <详情>
2020-02-27 12:26:00
整机柜服务器 H3C UniServer服务器首批搭载第二代英特尔至强处理器
近日,英特尔正式发布了第二代至强可扩展处理器——CascadeLakeRefresh。 <详情>
2020-02-27 11:43:10
整机柜服务器 同期下降15%,新型冠状肺炎影响一季度服务器/存储销售
根据IDC预测,2020年服务器总增长率将从最初的12.4%降低到7.4%,第一季度销售额将比去年同期下降15%,而不是原来的16.5%的预测。 <详情>