Nginx vs. HAProxy


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 vs. HAProxy】负载均衡
负载均衡是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 进程 都可以同时处理 数以千计 的 网络请求


推荐阅读