nginx upstream 的路由策略配置

nginx作反向代理时,提供了多种路由策略来决定请求该路由到哪一个后端节点。有轮询,最少连接,ip_hash,hash,sticky等。

1.weighted round-robin balancing(基于权重的轮询策略)

默认情况下nginx采用的轮询策略。

upstream backend {
    server backend1.example.com weight=3;
    server 127.0.0.1:8080       max_fails=3 fail_timeout=30s;
    server 127.0.0.1:8081
}

如上面3个后端服务权重占比为 3:1:1,意味着每5个请求,3个分给第一个,其他2个server 各一个

2. least_conn(最少连接数)

将请求转发给连接数最少的后端服务

upstream backend {
    least_conn;
    server backend1.example.com ;
    server 127.0.0.1:8080       max_fails=3 fail_timeout=30s;
    server 127.0.0.1:8081
}

3. ip_hash(基于客户端ip 进行hash)

根据客户端ip进行hash计算得到对应的后端节点,将请求路由至该节点。
但是如果有多级nginx代理,或者其他特殊的网络拓扑结构,有可能造成资源利用不重复,请求都路由到单个节点的情况。可以考虑hash路由

upstream backend {
    ip_hash;
    server backend1.example.com ;
    server 127.0.0.1:8080       max_fails=3 fail_timeout=30s;
    server 127.0.0.1:8081
}

4.hash (基于某个变量或者文本 进行hash算法 )

基于某个变量或者文本 进行hash算法 选择对应后端节点。可添加consistent,一致性hash参数,避免新加或移除节点时,hash大面积失效
nginx upstream 的路由策略配置_第1张图片
如下,基于proxy_add_x_forwarded_for变量,进行hash。在存在多级代理的情况下,nginx为了获取客户端真实ip,通常会设置一个 X_FORWARD_FOR的请求头参数,它的值由多个ip以逗号分割组成,第一个为客户端ip。如果存在多个代理,后续的为nginx代理ip。
proxy_add_x_forwarded_for 表示的意思是,$proxy_add_x_forwarded_for变量包含客户端请求头中的"X-Forwarded-For",与$remote_addr用逗号分开,如果没有"X-Forwarded-For" 请求头,则$proxy_add_x_forwarded_for等于$remote_addr。$remote_addr变量的值是客户端的IP。
nginx upstream 的路由策略配置_第2张图片

5.session sticky (基于cookie的session 粘黏 )

在upstream 中配置一个cookie属性,对于每一个路由至该upstream的请求,nginx会检查cookie有没有携带用于session粘黏的cookie,如果有则会根据cookie值,选择对应的server将请求,路由至该节点。如果没有对应的cookie,则会给它绑定一个server,将对应的cookie写入客户端。该特性属于nginx商业化特性。需要付费。不过网上有其他人写的类似功能的插件,可以参考:
https://blog.csdn.net/woshiji594167/article/details/85338045
nginx upstream 的路由策略配置_第3张图片

6.总结

nginx虽然提供了多种路由策略,但是对于软件服务架构偏向于微服务化的今天,默认轮训策略才是合适的。尽量减少系统的有状态性,才能使系统更加健壮,可用性更高。

你可能感兴趣的:(nginx,nginx,运维,哈希算法)