当前位置: 首页 > news >正文

Nginx配置负载均衡

Nginx配置负载均衡

使用nginx来配置负载均衡也是比较简单的

首先在http块中配置虚拟域名所对应的地址

    # 负载均衡upstream myserver {server 127.0.0.1:8080;server 127.0.0.1:8082;}

可以配置的参数有以下选项 #down 不参与负载均衡
#weight=5; 权重,越高分配越多 #backup; 预留的备份服务器
#max_fails 允许失败的次数
#fail_timeout 超过失败次数后,服务暂停时间
#max_coons 限制最大的接受的连接数
#根据服务器性能不同,配置适合的参数

然后在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 是否同步更改 uriproxy_redirect on | off;#允许客户端请求的最大单文件字节数client_max_body_size 10m; #缓冲区代理缓冲用户端请求的最大字节数client_body_buffer_size 128k;#nginx跟后端服务器连接超时时间(代理连接超时)proxy_connect_timeout 90; #后端服务器数据回传时间(代理发送超时)proxy_send_timeout 90; #连接成功后,后端服务器响应时间(代理接收超时)proxy_read_timeout 90; #设置代理服务器(nginx)保存用户头信息的缓冲区大小proxy_buffer_size 4k; #proxy_buffers缓冲区,网页平均在32k以下的设置proxy_buffers 4 32k;#高负荷下缓冲大小(proxy_buffers*2)proxy_busy_buffers_size 64k; #设定缓存文件夹大小,大于这个值,将从upstream服务器传proxy_temp_file_write_size 64k;}}

这样在使用9000端口访问服务器的时候就会进行8080和8082的负载调用

Nginx 负载均衡策略

轮询(默认)

按照时间顺序逐一的分配到不同的服务器,如果后端服务器挂掉,会自动删除,待恢复自动添加上

权重(weight)

weight代表权重,默认为1,权重越大分配的请求越多,weight和访问比率成正比,用于后端服务器性能不均的情况

    # 负载均衡upstream myserver {server 127.0.0.1:8080 weight=1;server 127.0.0.1:8082 weight=2;}
最少连接

使用最少连接的负载均衡,可以防止过多的请求都堆积到一台服务器上

# 负载均衡upstream myserver {least_conn;server 127.0.0.1:8080;server 127.0.0.1:8082;}
ip_hash

每个请求按照访问的ip进行hash分配,使得每个访问者固定访问某一个服务器,可以解决session问题

    # 负载均衡upstream myserver {ip_hash;server 127.0.0.1:8080;server 127.0.0.1:8082;}
url_hash

按照访问的url进行hash分配,每一个url定向到同一个后端服务器

upstream的fail_timeout和max_fails参数是用来判断负载均衡upstream中的某个server是否失效,在fail_timeout的时间内,nginx与upstream中某个server的连接尝试失败了max_fails次,则nginx会认为该server已经失效,在接下来的fail_timeout时间内,nginx不再将请求分发给失效的server

# 负载均衡
upstream myserver {hash $request_uri;# 指定hash算法hash_method crc32;server 127.0.0.1:8080;server 127.0.0.1:8082;
}
fair(第三方)

根据请求的响应时间来分配,哪个服务器响应的快分配给谁

    # 负载均衡upstream myserver {fair;server 127.0.0.1:8080;server 127.0.0.1:8082;}

https://zhhll.icu/2021/服务器/Nginx/7.配置负载均衡/

本文由 mdnice 多平台发布

http://www.lryc.cn/news/199055.html

相关文章:

  • Ubuntu 20.04 上安装 neo4j
  • 大规模爬虫系统面临的主要挑战及解决思路
  • 统计学习方法 感知机
  • Linux命令(103)之wc
  • 京东店铺公司名爬虫
  • 如何解决不同浏览器的样式兼容性问题?
  • C++ 中迭代器的使用
  • 如何使用BERT生成单词嵌入?
  • 第三章 内存管理 十一、虚拟内存的基本概念
  • web前端面试-- http的各个版本的区别(HTTP/0.9、HTTP/1.0、HTTP/1.1、HTTP/2.0、HTTP/3.0)
  • 统计学习方法 隐马尔可夫模型
  • Cypress 与 Selenium WebDriver
  • Leetcode 第 365 场周赛题解
  • 什么是软件测试? 软件测试都有什么岗位 ?软件测试和调试的区别? 软件测试和开发的区别?软件测试等相关概念入门篇
  • VI/VIM的使用
  • 【虹科干货】Redis Enterprise vs ElastiCache——如何选择缓存解决方案?
  • 2.2.2 交换机间相同vlan的通信
  • C的魅力在于指针
  • 【Linux常用命令14】Linux系统监控常用命令
  • Python Watchdog:高效的文件系统监控
  • C++中多态的原理【精华】
  • 亿赛通电子文档安全管理系统 Update.jsp SQL注入
  • 神经网络中的反向传播:综合指南
  • 协同创新、奔赴未来——“华为云杯”2023人工智能创新应用大赛华丽谢幕
  • 介绍Node.js中fs模块 代码和注释。
  • 【QT 读取JSON】 深入浅出 使用QT内置的QJson模块解析Json文件 匠心之作
  • 初识javaweb2 tomcat
  • 使用OPENROWSET :在一个数据库中查询另一个数据库的数据
  • 基于STM32设计的智慧农业管理系统(ESP8266+腾讯云微信小程序)
  • Flutter视图原理之三棵树的建立过程