您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
三六零分类信息网 > 哈密分类信息网,免费分类信息发布

nginx可以集群吗

2025/3/22 9:47:11发布15次查看
nginx可以集群吗?
nginx实现集群高可用
   大家知道nginx作为反向代理服务器可以实现负载均衡,同时也可以作为静态文件服务器,它的特点就是并发支持大,单机可同时支持3万并发,现在很多网站都把nginx作为网关入口来统一调度分配后端资源。但是如果nginx宕机了,就会导致整个后台服务无法使用;或者当并发量真的非常大时,达到十万级别时,一台nginx还是有极限的,所以这个时候就需要针对nginx进行主从备份保证服务高可用、集群来分担并发压力。目前,nginx在这两块主要有以下几种解决方案,我分别给大家介绍以下:
  nginx主从备份
  nginx实现主从备份目前主流方案是keepalived+nginx实现双机热备。
keepalived介绍:
keepalived是一个基于vrrp协议来实现的服务高可用方案,可以利用其来避免ip单点故障,类似的工具还有heartbeat、corosync、pacemaker。但是它一般不会单独出现,而是与其它负载均衡技术(如lvs、haproxy、nginx)一起工作来达到集群的高可用。
vrrp协议:
vrrp全称 virtual router redundancy protocol,即 虚拟路由冗余协议。可以认为它是实现路由器高可用的容错协议,即将n台提供相同功能的路由器组成一个路由器组(router group),这个组里面有一个master和多个backup,但在外界看来就像一台一样,构成虚拟路由器,拥有一个虚拟ip(vip,也就是路由器所在局域网内其他机器的默认路由),占有这个ip的master实际负责arp相应和转发ip数据包,组中的其它路由器作为备份的角色处于待命状态。master会发组播消息,当backup在超时时间内收不到vrrp包时就认为master宕掉了,这时就需要根据vrrp的优先级来选举一个backup当master,保证路由器的高可用。
在vrrp协议实现里,虚拟路由器使用 00-00-5e-00-01-xx 作为虚拟mac地址,xx就是唯一的 vrid (virtual router identifier),这个地址同一时间只有一个物理路由器占用。在虚拟路由器里面的物理路由器组里面通过多播ip地址 224.0.0.18 来定时发送通告消息。每个router都有一个 1-255 之间的优先级别,级别最高的(highest priority)将成为主控(master)路由器。通过降低master的优先权可以让处于backup状态的路由器抢占(pro-empt)主路由器的状态,两个backup优先级相同的ip地址较大者为master,接管虚拟ip。
具体实现原理:
1)master没挂,则master占有vip且nginx运行在master上
2)master挂了,则backup抢占vip且在backup上运行nginx服务
3)如果master服务器上的nginx服务挂了,则vip资源转移到backup服务器上
4)检测后端服务器的健康状态
master和backup两边都开启nginx服务,无论master还是backup,当其中的一个keepalived服务停止后,vip都会漂移到keepalived服务还在的节点上
nginx和keepalived安装配置
 它俩的安装配置比较多,还有编写脚本实现互相监控、报警等,所以咱们专门放一课来讲,这一课主要讲解决方案和原理。
nginx分布式集群
  如果有多台nginx想实现负载均衡的话,
1、每台nginx都有公网地址,在域名处设置同个域名多个指向,最简单实现轮洵。但故障切负会慢一点。
2、一台公网nginx通过upstream功能,轮洵、ip、url多方式分发到内网多台nginx。但公网的nginx如果down机的话,内网全段。
3、一对公网nginx加三个公网ip,通过keepalive实现高可用,再upstream到内网(就是我们刚刚上一节讲的主从备份)。
一般来说,上面1、2、3种方法基本可以解决,建议用2或3;
如果并发量真的巨大的话,一般就要借助硬件f5等设备做负载均衡,跟dns、cdn等服务商合作做域名解析转发、缓存配置,这也是目前大多数大厂的架构配置。
更多nginx相关技术文章,请访问nginx使用教程栏目进行学习!
以上就是nginx可以集群吗的详细内容。
哈密分类信息网,免费分类信息发布

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录