校招刷题群
高效刷题 迎战校招
校招精选试题
近年面笔经面经群内分享
Java刷题群 前端刷题群 产品运营群
首页 > 开源框架 > nginx分析
题目

Nginx负载均衡的算法怎么实现的?策略有哪些?

解答

为了避免服务器崩溃,大家会通过负载均衡的方式来分担服务器压力。将对台服务器组成一个集群,当用户访问时,先访问到一个转发服务器,再由转发服务器将访问分发到压力更小的服务器。

Nginx负载均衡实现的策略有以下五种:

1 轮询(默认)

每个请求按时间顺序逐一分配到不同的后端服务器,如果后端某个服务器宕机,能自动剔除故障系统。

upstream backserver { 
server 192.168.0.12;
server 192.168.0.13;
}

2 权重 weight

weight的值越大分配

到的访问概率越高,主要用于后端每台服务器性能不均衡的情况下。其次是为在主从的情况下设置不同的权值,达到合理有效的地利用主机资源。

upstream backserver { 
server 192.168.0.12 weight=2;
server 192.168.0.13 weight=8;
}

权重越高,在被访问的概率越大,如上例,分别是20%,80%。

3 ip_hash( IP绑定)

每个请求按访问IP的哈希结果分配,使来自同一个IP的访客固定访问一台后端服务器,并且可以有效解决动态网页存在的session共享问题

upstream backserver { 
ip_hash;
server 192.168.0.12:88;
server 192.168.0.13:80;
}

4 fair(第三方插件)

必须安装upstream_fair模块。

对比 weight、ip_hash更加智能的负载均衡算法,fair算法可以根据页面大小和加载时间长短智能地进行负载均衡,响应时间短的优先分配。

upstream backserver { 
server server1;
server server2;
fair;
}

哪个服务器的响应速度快,就将请求分配到那个服务器上。

5、url_hash(第三方插件)

必须安装Nginx的hash软件包

按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,可以进一步提高后端缓存服务器的效率。

upstream backserver { 
server squid1:3128;
server squid2:3128;
hash $request_uri;
hash_method crc32;
}
C 3条回复 评论
柚子上上签

上次做这道也错了……

发表于 2021-10-19 23:00:00
0 0
我吃小朋友

基础送分题目不能丢

发表于 2021-09-13 14:25:00
0 0
青辰

没看这篇帖子之前完全不懂该咋答

发表于 2021-09-08 16:50:01
0 0