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大面积失效 如下,基于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。
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
6.总结
nginx虽然提供了多种路由策略,但是对于软件服务架构偏向于微服务化的今天,默认轮训策略才是合适的。尽量减少系统的有状态性,才能使系统更加健壮,可用性更高。
|