您当前的位置:首页 > 电脑百科 > 站长技术 > 服务器

Nginx vs. HAProxy

时间:2022-02-07 09:49:29  来源:  作者:班博编程
Nginx vs. HAProxy

 

背景

随着互联网业务的迅猛发展,大型电商平台和门户网站对系统的可用性和可靠性要求越来越高,高可用集群、负载均衡集群成为一种热门的系统架构解决方案。在众多的负载均衡集群解决方案中,有基于硬件的负载均衡设备,例如F5、Big-IP等,也有基于软件的负载均衡产品,例如HAProxy、LVS、Nginx等,在软件的负载均衡产品中,又分为两种实现方式,分别是基于操作系统的软负载实现和基于第三方应用的软负载实现。LVS就是基于linux操作系统实现的一种软负载均衡,而Nginx、HAProxy就是基于第三应用实现的软负载均衡,本文将对比一下HAProxy、Nginx。

 

Nginx

介绍

Nginx(发音同engine x)是一款由俄罗斯程序员Igor Sysoev所开发轻量级的网页服务器、反向代理服务器以及电子邮件(IMAP/POP3)代理服务器。起初是供俄国大型的门户网站及搜索引擎Rambler(俄语:Рамблер)使用。

Nginx vs. HAProxy

 

特点

  • 轻量级,采用C进行编写,同样的web服务,会占用更少的内存及资源。
  • 抗并发,nginx以epollandkqueue作为开发模型,处理请求是异步非阻塞的。在高并发下nginx能保持低资源低消耗高性能
  • 可以配置nginx的upstream实现nginx的反向代理。
  • nginx作为负载均衡服务器,支持7层负载均衡。
  • 支持高并发连接,每秒最多的并发连接请求理论可以达到50000个。
  • nginx配置简洁,正则配置让很多事情变得简单
  • 用线程处理用户请求,而线程是共享内存的,只需要开启少量进程,多个线程就可以共享进程的内存,占用内存小。
  • nginx的设计高度模块化,编写模块相对简单。
  • 社区活跃,各种高性能模块出品迅速。

负载均衡

负载均衡是Nginx常用的一个功能,是在服务端通过的负载均衡算法实现的,Nginx也要具有很多不同的负载均衡策略。负载均衡的意思是将请求分摊到不同的服务器上执行,例如:web服务器、企业内部服务器等等,这样可以提高系统的吞吐量和请求的响应速度。

Nginx vs. HAProxy

 

负载均衡算法

  • 轮询:轮询方式是Nginx负载默认的方式,顾名思义,所有请求都按照时间顺序分配到不同的服务上,如果服务Down掉,可以自动剔除
  • 权重:指定每个服务的权重比例,weight和访问比率成正比,通常用于后端服务机器性能不统一,将性能好的分配权重高来发挥服务器最大性能
  • IP地址散列:每个请求都根据访问ip的hash结果分配,经过这样的处理,每个访客固定访问一个后端服务
  • 最少连接:将请求分配到连接数最少的服务上
  • fair:按后端服务器的响应时间来分配请求,响应时间短的优先分配
  • URL散列:通过管理客户端请求URL信息的散列,将发送至相同URL的请求转发至同一服务器的算法

架构

Nginx vs. HAProxy

 

主进程(master)

Nginx 启动时,会生成两种类型的 进程 *,一个是 主进程 ( master ), 一个 ( windows版本的目前只有一个)或 多个工作进程 ( worker )。 主进程 并不处理网络请求,主要负责 调度工作进程 , 加载配置 、 启动工作进程 及 非停升级 。所以, Nginx 启动以后,查看操作系统的进程列表,我们就能看到 至少有两个 Nginx 进程。

工作进程(worker)

服务器实际 处理网络请求 及 响应 的是 工作进程 ( worker ),在类 unix 系统上, Nginx可以配置 多个 worker ,而每个 worker 进程 都可以同时处理 数以千计 的 网络请求

 

HAProxy

介绍

HAProxy是法国人Willy Tarreau 使用C语言编写的自由及开放源代码软件,其提供高可用性、负载均衡,以及基于TCP和HTTP的应用程序代理。HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或七层处理。HAProxy运行在当前的硬件上,完全可以支持数以万计的并发连接。并且它的运行模式使得它可以很简单安全地整合进您当前的架构中, 同时可以保护你的web服务器不被暴露到网络上。

Nginx vs. HAProxy

 

特点

  • 可靠性和稳定性非常好,可以与硬件级的F5负载均衡设备相媲美;
  • 最高可以同时维护40000-50000个并发连接,单位时间内处理的最大请求数为20000个,最大处理能力可达10Git/s;
  • 支持多达8种负载均衡算法,同时也支持会话保持;
  • 支持虚拟机主机功能,从而实现web负载均衡更加灵活;
  • 支持连接拒绝、全透明代理等独特的功能;
  • 拥有强大的ACL支持,用于访问控制;
  • 其独特的弹性二义树数据结构,使数据结构的复杂性上升到了0(1),即数据的查寻速度不会随着数据条日的增加而速度有所下降;支持客户端的keepalive功能,减少客户端与haproxy的多次三次握手导致资源浪费,让多个请求在一个tcp连接中完成;
  • 支持TCP加速,零复制功能,类似于mmap机制;
  • 支持响应池(response buffering) ;
  • 支持RDP协议;
  • 基于源的粘性,类似nginx的ip hash功能,把来自同一客户端的请求在一定时间内始终调度到上游的同一服务器;·更好统计数据接口,其web接口显示后端集群中各个服务器的接收、发送、拒绝、错误等数据的统计信息;
  • 详细的健康状态检测,web接口中有关于对上游服务器的健康检测状态,并提供了一定的管理功能;
  • 基于流量的健康评估机制;
  • 基于http认证;
  • 基于命令行的管理接口;
  • 日志分析器,可对日志进行分析。

负载均衡

Nginx vs. HAProxy

 

负载均衡算法

  • roundrobin:表示简单的轮询,这个不多说,这个是负载均衡基本都具备的;
  • static-rr:表示根据权重
  • leastconn:表示最少连接者先处理
  • source:这个跟 Nginx 的 IP_hash 机制类似
  • ri:表示根据请求的 URI;
  • rl_param:表示根据请求的 URl 参数’balance url_param’ requires an URLparameter name;
  • hdr(name):表示根据 HTTP 请求头来锁定每一次 HTTP 请求;
  • rdp-cookie(name):表示根据据 cookie(name)来锁定并哈希每一次 TCP 请求。

 

架构

HAProxy实现的是一种事件驱动、单一进程的架构模型,此类模型的优点在于能够支撑高并发大规模的连接。反之,多进程或多线程模型受内存和系统调度器的限制以及无处不在的锁限制,很难应对数以万计的高并发连接。HAProxy支持连接拒绝,通过拒绝连接,可以限制某些非法或有意的攻击型连接,从而降低其对网站带来的危害。的这一功能已成为目前应对小型 DDoS攻击的主要方法之一,并且其他负载均衡器很难做到这点。此外, HAProxy还支持全透明代理,即可以将客户端地址或者任何指定地址直接连接到后端服务器,通过全透明代理,可以不用修改某些特殊服务器地址而使其直接接收并处理部分特定流量。

工作模式如下

  • tcp模式:该模式下,在客户端和服务器之间将建立一个全双工的连接,且不会对7层的报文做任何处理的简单模式。此模式默认,通常用于SSL、SSH、SMTP应用。
  • http模式(一般使用):该模式下,客户端请求在转发给后端服务器之前会被深度分析,所有不与RFC格式兼容的请求都会被拒绝。
  • health模式 : 仅做健康检查

 

总结

从定位上来说,nginx重点是web服务器,替换的是Apache,同时具备lb的作用,haproxy是单纯的lb。二者现在都能支持http/tcp/udp的负载均衡,nginx的采用类似编程语言的配置,用文档结构表示配置关系,看起来比较清晰,haproxy的配置有点像网络设备,定义和引用,有时候搞清一个逻辑需要上下来回翻看。nginx是master-workers多进程,每个进程单线程,多核CPU能充分利用;haproxy是多线程,单进程就能实现超高性能,虽然haproxy也能多进程,但是网上资料多认为开了多进程也不能提升性能,不建议多进程跑。即使做反向代理nginx性能略低于haproxy,但实际两者性能都超高,



Tags:Nginx   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
背景随着互联网业务的迅猛发展,大型电商平台和门户网站对系统的可用性和可靠性要求越来越高,高可用集群、负载均衡集群成为一种热门的系统架构解决方案。在众多的负载均衡集...【详细内容】
2022-02-07  Tags: Nginx  点击:(7)  评论:(0)  加入收藏
因为工作网络的特殊性,服务器是不连互联网的,所以整个安装过程都是采用离线包安装的方式来安装。Nginx安装用root用户安装,采用源代码编译的方式来进行安装,首先下载nginx安装要...【详细内容】
2022-01-28  Tags: Nginx  点击:(24)  评论:(0)  加入收藏
需要在服务器上实现个TCP服务器, 由于已安装了nginx, 所以在nginx中给TCP开个口子。stream模块网上文章的说法都是, 1.9.0版之后nginx开始具有TCP/UDP的代理转发功能, 但需...【详细内容】
2022-01-25  Tags: Nginx  点击:(16)  评论:(0)  加入收藏
开源版 Nginx 最为人诟病的就是不具备动态配置、远程 API 及集群管理的能力,而 APISIX 作为 CNCF 毕业的开源七层网关,基于 etcd、Lua 实现了对 Nginx 集群的动态管理。让 Ngi...【详细内容】
2022-01-14  Tags: Nginx  点击:(25)  评论:(0)  加入收藏
一、背景介绍Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。二、安装$ wget http://nginx.org/download/nginx-1.14.2.tar.gz#...【详细内容】
2022-01-04  Tags: Nginx  点击:(36)  评论:(0)  加入收藏
安装Nginx在Mac上有一个很好用的包管理插件,名为homebrew。 具体的安装可以自行去搜索下。下面就借助Homebrew来安装Nginx。首先是拉取Nginx$ brew tap home/nginx执行安装$...【详细内容】
2021-12-31  Tags: Nginx  点击:(41)  评论:(0)  加入收藏
项目中,遇到了一个问题,就是PDF等文档不能够在线预览,预览时会报错。错误描述浏览器的console中,显示如下错误:nginx代理服务报Mixed Content: The page at ******** was loaded...【详细内容】
2021-12-17  Tags: Nginx  点击:(39)  评论:(0)  加入收藏
前言Nginx是前后端开发工程师必须掌握的神器。该神器有很多使用场景,比如反向代理、负载均衡、动静分离、跨域等等。把 Nginx下载下来,打开conf文件夹的nginx.conf文件,Nginx服...【详细内容】
2021-12-08  Tags: Nginx  点击:(45)  评论:(0)  加入收藏
最近客户有个新需求,就是想查看网站的访问情况,由于网站没有做google的统计和百度的统计,所以访问情况,只能通过日志查看,通过脚本的形式给客户导出也不太实际,给客户写个简单的页...【详细内容】
2021-10-09  Tags: Nginx  点击:(67)  评论:(0)  加入收藏
安全服务器是只允许所需数量的服务器。理想情况下,我们将通过单独启用其他功能来基于最小系统构建服务器。进行最少的配置也有助于调试。如果该错误在最小系统中不可用,则分别...【详细内容】
2021-09-26  Tags: Nginx  点击:(76)  评论:(0)  加入收藏
▌简易百科推荐
最近测试反馈了一个问题,每次重启服务器,我们某个版本的业务系统中的机器码都会改变,导致根据机器码算出来的许可证失效,从而使软件无法使用。 这个问题反馈了有一段时间了,但是...【详细内容】
2022-02-10  互联网活化石    Tags:cpuid   点击:(3)  评论:(0)  加入收藏
背景随着互联网业务的迅猛发展,大型电商平台和门户网站对系统的可用性和可靠性要求越来越高,高可用集群、负载均衡集群成为一种热门的系统架构解决方案。在众多的负载均衡集...【详细内容】
2022-02-07  班博编程    Tags:Nginx   点击:(7)  评论:(0)  加入收藏
主旨本文的目的是为了解决两台服务器之间目录差异问题,即可以在A、B两台服务器指定目录写、删任何内容,都会同步到另一台服务器,即实现文件存放、读取高可用。环境服务器信息:n...【详细内容】
2022-01-31  运维家    Tags:linux服务器   点击:(14)  评论:(0)  加入收藏
什么是Gunicorn?Gunicorn(绿色独角兽)是一个用于UNIX的Python WSGI HTTP服务器。这是从Ruby的Unicorn项目移植来的一个前fork工作器模型。Gunicorn服务器广泛兼容各种web框架,并...【详细内容】
2022-01-30  怀揣梦想的软件人生    Tags:Gunicorn   点击:(21)  评论:(0)  加入收藏
因为工作网络的特殊性,服务器是不连互联网的,所以整个安装过程都是采用离线包安装的方式来安装。Nginx安装用root用户安装,采用源代码编译的方式来进行安装,首先下载nginx安装要...【详细内容】
2022-01-28  ctools    Tags:nginx   点击:(24)  评论:(0)  加入收藏
需要在服务器上实现个TCP服务器, 由于已安装了nginx, 所以在nginx中给TCP开个口子。stream模块网上文章的说法都是, 1.9.0版之后nginx开始具有TCP/UDP的代理转发功能, 但需...【详细内容】
2022-01-25  有AI野心的电工和码农    Tags:nginx   点击:(16)  评论:(0)  加入收藏
奇葩的要求年年有,这个要求特别怪,跑路的网管有这么可怕吗?付费让我们重置了防火墙,还要求我们重建域服务器和文件服务器。等我们建立好域控,部署完文件服务器,权限也设置完毕,却又...【详细内容】
2022-01-25  IT狂人日志    Tags:服务器   点击:(21)  评论:(0)  加入收藏
Ingress配置转发端口本质Ingress配置转发端口本质,还是利用service nodePort能力,通过暴露ingress的本地端口来转发。Ingress默认不支持TCP or UDP services。因此Ingress con...【详细内容】
2022-01-21  爱思考乔斯林0H0    Tags:kubernetes   点击:(44)  评论:(0)  加入收藏
对于普通人来说,云计算是一个离我们很近,同时离我们也很远的存在。之所以说它“近”,是因为云计算的应用已经深入到我们生活的方方面面,由云服务器所承载的各类程序应用已经无处...【详细内容】
2022-01-14    中关村在线  Tags:云服务器   点击:(21)  评论:(0)  加入收藏
很多站长都发现了同一问题,就是网站使用时间长了,卡顿延迟的问题越来越明显。我们可以看看是不是网站的虚拟主机流量被限制了。很多站长可能不知道,虚拟主机被限制流量是什么回...【详细内容】
2022-01-10  群英网络  搜狐号  Tags:流量限制   点击:(39)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条