架构之_haproxy调度算法

haproxy的调度算法

架构之_haproxy调度算法
balance:指明对后端服务器的调度算法,配置在listen或backend

1.静态调度算法
静态算法:按照事先定义好的规则轮询公平调度,不关心后端服务器的当前负载、链接数和相应速度等,且无法实时修改权重,只能重启后生效。
1)static-rr:基于权重的轮询调度
                   不支持权重的运行时调整及后端服务器慢启动
                   其后端主机数量没有限制
2)first:根据服务器在列表中的位置,自上而下进行调度,但是其只会当第一台服务器的连接数达到上限,新请求才会分配给下一台服务,因此会忽略服务器的权重设置。
示例:
listen WEB_PORT_80
bind 172.18.200.101:80
mode http
balance first
server web1 172.18.200.103:80 wegiht 1 check inter 3000 fall 3 rise 5
server web2 172.18.200.104:80 wegiht 1 check inter 3000 fall 3 rise 5

2.动态调度算法
动态算法:基于后端服务器状态进行调度适当调整,比如优先调度至当前负载较低的服务器,且权重可以在haproxy运行时动态调整无需重启。
1)roundrobin:基于权重的轮询动态调度算法
                         支持权重的运行时调整,不等于lvs 的rr
                         支持慢启动(即新加的服务器会逐渐增加转发数)
                         每个后端backend中最多支持4095个server
                         此为默认调度算法
                         server 权重设置weight
2)leastconn:加权的最少连接的动态,支持权重的运行时调整和慢启动,即当前后端服务器连接最少的优先调度,比较适合长连接的场景使用,比如MySQL等场景。

3.source
source:源地址hash,基于用户源地址hash并将请求转发到后端服务器,
              默认为静态即取模方式,但是可以通过hash-type支持的选项更改
              后续同一个源地址请求将被转发至同一个后端web服务器
              比较适用于session保持/缓存业务等场景。
1)map-based:取模法,基于服务器权重的hash数组取模,该hash是静态的即不支持在线调整权重,不支持慢启动,其对后端服务器调度均衡
                         缺点:是当服务器的总权重发生变化时,即有服务器上线或下线,都会因权重发生变化而导致调度结果整体改变,hash(o)modn
架构之_haproxy调度算法
2)consistent:一致性哈希,该hash是动态的,支持在线调整权重,支持慢启动
                       优点:在于当服务器的总权重发生变化时,对调度结果影响是局部的,不会引起大的变动。
架构之_haproxy调度算法
架构之_haproxy调度算法
示例:
listen web_prot_http_nodes
bind 192.168.7.101:80
mode http
balance source
hash-type consistent
log global
option forwardfor
server 192.168.7.101 192.168.7.101:8080 check inter 3000 fall 3 rise 5
server 192.168.7.102 192.168.7.102:8080 check inter 3000 fall 3 rise 5

4.uri
uri:基于对用户请求的uri做hash并将请求转发到后端指定服务器
map-based:取模法
consistent:一致性哈希
    http://example.org/absolute/URI/with/absolute/path/to/resource.txt #URI/URL
    ftp://example.org/resource.txt #URI/URL
    /relative/URI/with/absolute/path/to/resource.txt #URI
URL:(Uniform/Universal Resource Locator 的缩写,统一资源定位符)。
URI:(Uniform Resource Identifier 的缩写,统一资源标识符)(代表一种标准)
关系:
URI 属于 URL 更高层次的抽象,一种字符串文本标准。
就是说,URI 属于父类,而 URL 属于 URI 的子类。URL 是 URI 的一个子集。
二者的区别在于,URI 表示请求服务器的路径,定义这么一个资源。而 URL 同时说明要如何访问这个资源(http://)
架构之_haproxy调度算法
示例:
listen web_prot_http_nodes
bind 192.168.7.101:80
mode http #不支持tcp,会切换到tcp的roundrobin负载模式
balance uri
hash-type consistent
log global
option forwardfor
server 192.168.7.101 192.168.7.101:8080 check inter 3000 fall 3 rise 5
server 192.168.7.102 192.168.7.102:8080 check inter 3000 fall 3 rise 5

5.url_param
url_param:对用户请求的url中的<params>部分中的参数name作hash计算,并由服务器总权重相除以后派发至某挑出的服务器;通常用于追踪用户,以确保来自同一个用户的请求始终发往同一个Backend Server
假设url= http://www.magedu.com/foo/bar/index.php?k1=v1&k2=v2
则:
host = "www.magedu.com"
url_param= "k1=v1&k2=v2"
示例:
listen web_prot_http_nodes
bind 192.168.7.101:80
mode http #不支持tcp,会切换到tcp的roundrobin负载模式
balance url_param name #基于参数name做hash
hash-type consistent
log global
option forwardfor
server 192.168.7.101 192.168.7.101:8080 check inter 3000 fall 3 rise 5
server 192.168.7.102 192.168.7.102:8080 check inter 3000 fall 3 rise 5

6.hdr
hdr(<name>):针对用户每个http头部(header)请求中的指定信息做hash,此处由<name>指定的http首部将会被取出并做hash计算,然后由服务器总权重相除以后派发至某挑出的服务器,假如无有效的值,则会被轮询调度
hdr( Cookie、User-Agent、host )
示例:
listen web_prot_http_nodes
bind 192.168.7.101:80
mode http
balance hdr(User-Agent)
hash-type consistent
log global
option forwardfor
server 192.168.7.101 192.168.7.101:8080 check inter 3000 fall 3 rise 5
server 192.168.7.102 192.168.7.102:8080 check inter 3000 fall 3 rise 5

7.rdp-cookie
rdp-cookie对远程桌面的负载,使用cookie保持会话
rdp-cookie(<name>)
示例:
listen RDP
bind 192.168.7.101:3389
balance rdp-cookie
mode tcp
server rdp0 172.18.139.20:3389 check fall 3 rise 5 inter 2000 weight 1
server rdp1 172.18.139.21:3389 check fall 3 rise 5 inter 2000 weight 1
基于iptables实现目标地址转换:
iptables -t nat -A PREROUTING -d 192.168.7.101 -p tcp --dport 3389 -j DNAT --to-destination
172.18.139.20:3389
iptables -t nat -A POSTROUTING -s 192.168.0.0/21 -j SNAT --to-source 192.168.7.101

上一篇:dotnet设计规范·抽象定义


下一篇:Let the Balloon Rise