评论

收藏

[Nginx] Nginx如何配置负载均衡

web服务器 web服务器 发布于:2021-08-08 21:23 | 阅读数:352 | 评论:0

目录

  • Nginx配置负载均衡
  • Nginx 负载均衡策略

    • 轮询(默认)
    • 权重(weight)
    • ip_hash
    • fair(第三方)


Nginx配置负载均衡
使用nginx来配置负载均衡也是比较简单的
首先在http块中配置虚拟域名所对应的地址
# 负载均衡
upstream myserver {
 server 127.0.0.1:8080;
 server 127.0.0.1:8082;
}
然后在server块中配置监听
server {
 listen  9000;
 server_name localhost;
 
 location / {
  root html;
  index index.html index.htm;
  # 对应上述upstream所配置的名称
  proxy_pass http://myserver;
  
  ### 下面都是次要关注项
  proxy_set_header Host $host;
  proxy_method POST;
 
   # 指定不转发的头部字段
  proxy_hide_header Cache-Control;
 
   # 指定转发的头部字段
  proxy_pass_header Server-IP;
 
   # 是否转发包体
  proxy_pass_request_body on | off;
 
   # 是否转发头部
  proxy_pass_request_headers on | off;
 
   # 显形/隐形 URI,上游发生重定向时,Nginx 是否同步更改 uri
  proxy_redirect on | off;
 }
}
这样在使用9000端口访问服务器的时候就会进行8080和8082的负载调用

Nginx 负载均衡策略

轮询(默认)
按照时间顺序逐一的分配到不同的服务器,如果后端服务器挂掉,会自动删除

权重(weight)
weight代表权重,默认为1,权重越大分配的请求越多
# 负载均衡
upstream myserver {
 server 127.0.0.1:8080 weight=1;
 server 127.0.0.1:8082 weight=2;
}
ip_hash
每个请求按照访问的ip进行hash分配,使得每个访问者固定访问某一个服务器,可以解决session问题
# 负载均衡
upstream myserver {
  ip_hash;
 server 127.0.0.1:8080;
 server 127.0.0.1:8082;
}
fair(第三方)
根据请求的响应时间来分配,哪个服务器响应的快分配给谁
以上就是Nginx如何配置负载均衡的详细内容,更多关于Nginx配置负载均衡的资料请关注服务器之家其它相关文章!
原文链接:http://zhhll.icu/2021/02/12/Nginx/%E9%85%8D%E7%BD%AE%E8%B4%9F%E8%BD%BD%E5%9D%87%E8%A1%A1/

关注下面的标签,发现更多相似文章