这篇文章主要介绍了关于nginx应用:使用nginx进行负载均衡,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下
nginx一般可以用于七层的负载均衡,这篇文章将介绍一些负载均衡的基本知识以及使用nginx进行负载均衡的简单的例子。
四层负载均衡 vs 七层负载均衡
经常会说七层负载均衡还是四层负载均衡,其实根据ISO的OSI网络模型的所在层的叫法而决定的,nginx因为在使用http协议在应用层进行负载均衡的操作,所以被称为七层负载均衡。而诸如LVS在TCP层进行负载均衡操作的则被称为四层负载均衡。一般来说,有如下层的负载均衡分类:
类别 | OSI模型层 | 说明 |
---|---|---|
二层负载均衡 | MAC层 | 根据MAC地址进行响应 |
三层负载均衡 | IP层 | 根据IP地址进行响应 |
四层负载均衡 | TCP层 | 在IP地址的基础上结合端口号进行响应 |
七层负载均衡 | HTTP层 | 在四层的基础上,可继续根据URL/浏览器类别等七层的信息进行进一步的响应 |
常见软件的支持
软件 | 四层负载均衡 | 七层负载均衡 |
---|---|---|
nginx | 轻量实现 | 支持http和mail,性能与haproxy相近 |
haproxy | – | 支持七层负载均衡 |
LVS | 支持四层负载均衡,实现较重 | – |
F5 | 硬件实现,成本高 | – |
常见的负载均衡算法
负载均衡常见有如下几种算法:
负载均衡算法 | 负载均衡算法(E) | nginx支持与否 | 说明 | 适用场景 |
---|---|---|---|---|
普通轮询 | Round Robin | 支持 | 权重相同的轮询 | 适用于外部服务请求和内部服务器都相对均衡的场景 |
权重轮询 | Weighted Round Robin | 支持(weight) | 可以设定不同权重进行轮询 | 服务器的处理能力不同,或则希望进行流量的控制,比如Canary Release |
随机均衡 | Random | – | 随机分配给服务器 | 外部和内部均非常均衡的场合,或者需要随机的分配的需求较强 |
权重随机 | Weighted Random | – | 结合权重随机分配给服务器 | 可结合权重调节随机策略,更好地适应现实中分布状况 |
响应速度 | Response Time | 支持(fair) | 根据服务器的响应速度进行分配 | 服务器性能和服务器当前运行状况的结合,此种策略能动态的调整状态,避免能者已经不能的情况下仍然被大量分配作业 |
最少连接 | Least Connection | 根据连接的数量进行分配 | 轮询做的是分配任务,由于实际情况中来&源gao@dai!ma.com搞$代^码%网 | |
DNS响应 | Flash DNS | – | 根据最快返回的DNS解析结果来继续请求服务,忽略其他DNS返回的IP地址 | 适用于具有全局负载均衡的情况下,比如CDN |