轮询(Round Robin):每一次来自网络的请求轮询分配给内部中的服务器,从1至N然后重新开始。此种均衡算法适合于服务器组中的所有服务器都有相同的软硬件配置并且平均服务请求相对均衡的情况。
权重(Weight):根据服务器的不同处理能力,给每个服务器分配不同的权重,使其能够接受相应权值数的服务请求。例如:服务器A的权重被设计成1,B的权重是3,,C的权值是6,则服务器A、B、C将分别接受到10%、30%、60%的服务请求。此种算法能确保高性能的服务器得到更多的使用率,避免低性能的服务器负载过重。
随机(Random):把来自网络的请求随机分配给内部中的多个服务器。
权重随机(Weight Random Robin):类似于权重算法,不过在处理请求分担时是个随机选择的过程。
相响应速度(Response Time探测时间):负载均衡设备对内部各服务器发出一个探测请求(例如ping),然后根据内部中各服务器对探测请求的最快响应时间来决定哪一台服务器来响应客户端的服务请求。此种算法能较好的反应服务器的当前运行状态,但这最快响应时间仅仅指的是负载均衡设备与服务器间的最快响应时间,而不是客户端与服务器间的最快响应时间。
最少连接数(Least Connection):最小连接数算法是对内部中需负载的每一台服务器都有一个数据记录,记录当前该服务器正在处理的连接数量,当有新的服务连接请求时,将把当前请求分配给连接数最少的服务器,使均衡更加符合实际情况,负载更加均衡。此种均衡算法适合长时间处理的请求服务,如FTP。
处理能力均衡(CPU、内存):此种算法把服务请求分配给内部中处理负荷(根据服务器CPU、CPU数量、内存大小及当前连接数等换算而成)最轻的服务器,由于考虑到了内部服务器的处理能力然后及当前网络运行状况,所以此种均衡算法相对来说更加精确,尤其适合运用到第七层(应用层)负载均衡的情况下。
DNS响应均衡(Flash DNS):分处在不同地理位置的负载设备收到同一个客户端的域名解析请求,并在同一时间把此域名解析成各自对应服务器的IP地址并返回给客户端,则客户端将以最先收到的域名解析IP地址来继续请求服务,而忽略其他的IP地址响应。在这种均衡策略适合应用在全局负载均衡的情况下,对本地负载均衡时没有意义的。
哈希算法(Hash):一致性哈希,相同参数的请求总是发出同一提供者。当某一台提供者挂时,原本发往该提供者的请求,基于虚拟节点,平摊到其他提供者,不会引起剧烈变动。
IP地址散列(保证客户端服务器对应关系稳定):通过管理发送方IP和目的地IP地址的散列,将来自同一发送方的分组(或发送至一目的地的分组)同一转发到相同服务器的算法。当客户端有一系列业务需要处理而必须和一个服务器反复通信时,该算法能够以流(会话)为单位,保证来自相同客户端的通信能够一直在同一服务器中进行处理。
URL散列:通过管理客户端请求URL信息的散列,将发送至相同URL的请求转发至同一服务器的算法。