在使用haproxy时在backend段会用到balance以指明用何种方式实现后端服务器的调度。

balance:指明调度算法

  动态算法:权重可以动态调整

  静态算法:调整权重不会实时生效,只能重启才能生效

  balance的算法有:roundrobin,static-rr,leastconn,source,uri,uri_param,hdr等

roundrobin算法:

  轮询,基于权重进行轮询,此算法是动态的,每个后端服务器仅能最多接受4128个连接;

  要求后端不能有状态及会话方面的等,只能是静态的页面

  当后端有会话等动态信息时,结合cookie使用,效果最佳

static-rr算法:

  静态的roundrobin,不支持动态调整;静态算法,每个后端主机支持的数量无上限;

leastconn算法:

  根据后端主机的负载数量进行调度,新的连接请求被派发至具有最少连接数目的后端服务器;

  在长连接会话的场景中推荐使用此法,不适用http,动态算法

source算法:

  将请求的源地址进行hash运算;由后端服务器的权重总数相除后派发至某匹配的服务器,此方法可以让   同一个IP的请求发往同一个服务器;不过,当服务器权重总数发生变化时,如某服务器宕机或添加了   新的服务器,许多客户端的请求可能会被派发至与此前请求不同的服务器;常用于负载均衡无cookie   功能的基于TCP的协议;其默认为静态,不过也可以使用hash-type修改此特性;

  hash-type:

    map-based:取模法(除模取余法);(静态的,默认的)

    consistent:一致性哈希法;(动态的,使后时需要指定:hash-type consistent)

uri算法:

  对URI的左半部分(“问号”标记之前的部分)或整个URI进行hash运算,并由服务器的总权重相除后派 发至某匹配的服务器;这可以使得对同一个URI的请求总是被派发至某特定的服务器,除非服务器的权重总数发生了变化;此算法常用于代理缓存或反病毒代理以提高缓存的命中率

  例:http://www.baidu.com/abc/query?item=123  #红色标记的部分是uri部分

  hash-type:

    map-based:取模法(除模取余法);(静态的,默认的)

    consistent:一致性哈希法;(动态的,使后时需要指定:hash-type consistent)

  注:用到uri时,当访问过后端某个页面后,后面所有此页面的请求都发至此服务器

  当未访问过后端某个页面时,采用roundrobin算法,随机挑选一个响应,并且随后所有的此页面的请求都发至此主机,这种算法,当后端缓存时非常有效果!!!!  

roundrobin算法结合cookie的用法:

  cookie的作用是基本浏览器实现session sticky;

  cookie的使用方法:cookie [rewrite|insert|prefix] [indirect] [nocache]   

  [rewrite|insert|prefix]:添加cookie的方式

    rewrite:把原有的cookie替换

    insert:在原有的cookie后中插入 #此种方式最为常用

    prefix:在原有的cookie前插入

  cookie常使用的方式:

    cookie SERVERID insert indirect nocache

    注:

    a.SERVERID,是自己随便指定的,在下面的例子中就是SERVERID=websrv1,SERVERID=websrv2;insert:表示插入原有cookie后边

    b.不根据源IP进行绑定,根据不同客户端的进行绑定,这种方式我感觉比source要好,因为source是把同一IP的发往同一后端服务器;根据不同客户端绑定,可以实现同一个公网IP的用户,请求发送到不同的后端

    c.roundrobin算法,结合cookie这种方式可以进行尝试;这种方式弥补了roundrobin不保持会话的缺点

  用法实例:    

    balance roundrobin

    cookie SERVERID insert indirect

    server web1 192.168.0.100 check weight 1 cookie websrv1

    server web2 192.168.0.101 check weight 3 cookie websrv2

    注:websrv1:是web1专有的cookie标识符,在客户端浏览器的cookie中可以看到

        websrv2:是web2专有的cookie标识符,在客户端浏览器的cookie中可以看到

最常用的算法为:

  roundrobin

  source

  uri