nginx怎么负载均衡

发布时间 - 2019-06-20 00:00:00    点击率:

一、Nginx反向代理

在介绍nginx的负载均衡之前,我们先来介绍nginx的反向代理,因为反向代理用的比较多,所以,这里我们就不介绍正向代理了。

nginx的代理过程,就是将请求发送给nginx,然后将请求转发给后端服务器,后端服务器处理完毕之后将结果再发给nginx,nginx再把结果发送给客户端。后端服务器可在远程也可在本地,也可以是nginx服务器内部定义的其他虚拟主机。这些接收nginx转发的服务器被称为上游(upstream)

使用nginx做代理的目的之一是扩展基础架构的规模。nginx可以处理大量并发连接,请求到来后,nginx可将其转发给任意数量的后台服务器进行处理,这等于将负载均衡分散到整个集群。

语法:proxy_pass URL

解释:URL的形式可以如下:http://location:8000/uri/等,可在location中进行配置。

例:我们来写一个简单的反向代理:

在我80端口监听的目录下没有test_proxy的文件,但在我8080端口监听目录下有,我在80端口的server里面添加如下内容:

location ~ /test_proxy.html$ {proxy_pass http://127.0.0.1:8080;}

然后在浏览器上输入http://IP地址/test_proxy.html,会出现请求的信息,实际上是80端口转发给了8080端口并把数据请求了回来。

二、缓冲

nginx也提供了缓冲的机制,用于提高性能。没有缓冲的情况下,数据直接从后端服务器发送给客户端。缓冲的作用是在nginx上临时存储来自后端服务器的处理结果,从而可以提早关闭nginx到后端的连接,减少IO的损耗。一般内容存放在内存当中,但当内容过多,造成的内存不够时,会把内容存放在临时文件目录下。下面是一些常用的缓冲的配置项,可以再http、server和location内容块下。

proxy_buffering:控制本内容块下是否启用缓冲,默认是"on"。

proxy_buffers:有两个参数,第一个控制缓冲区请求数量,第二个控制缓冲区大小。默认值为8个、一页(一般是4k或8k)。这个值越大,缓冲的内容越多。

proxy_buffer_size:后端回复结果的首段(包含header的部分)是单独缓冲的,此配置就是配置这部分缓冲区的大小。这个值默认与proxy_buffer的值相同,我们可以把它设置得小一些,因为header内容一般比较少。

proxy_busy_buffers_size:设置被标记为"client-ready"(客户端就绪)的缓冲区大小。客户端一次只能从一个缓冲读取数据,而缓冲是按照队列次序被分批发送给客户端的。此语法配置的就是这个队列的大小。

proxy_temp_path:定义nginx存储临时文件路径。

proxy_max_temp_file_size:每个请求可以存储临时文件的目录大小。如果上游发来的结果太大以至于无法放入一个缓冲,则nginx会为其创建临时文件。

三、负载均衡

配置语法:upstream name {.......}

解释:name是自定义的一个名字,而{}则是需要定义的内容,只能在http块定义,不能在server块里定义。定义完之后可在location块下写入如下代码进行调用:http://name。

例:由于服务器数量的限制,此处我们是用一台服务器的不同的端口来模拟负载均衡,当然,多台的配置也是差不多的。

在server块内加入如下代码:

upstream test {#ip_hash server IP:8001; server IP:8002; server IP:8003;}

然后,我们在http块内的location中加入如下内容:

location / {#设置主机头和客户端真实地址,以便服务器获取客户端真实IPproxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_connect_timeout 30;#设置连接超时时间为30sproxy_send_timeout 60; proxy_read_timeout 60; proxy_buffer_size 32k; #设置缓冲区大小 proxy_buffering on; #开启缓冲区 proxy_buffers 4 128k; #设置缓冲区的数目和大小 proxy_busy_buffers_size 256k; #设置客户端就绪缓冲区大小 proxy_max_temp_file_size 256k; proxy_pass http://test; #调用上面设置的负载均衡 }

当然,得提醒一下,我们设置的IP的端口是事先在配置文件里配置好的。例如如下的配置。

然后,我们访问我们的主机地址,然后不断的刷新,会发现出来每个端口出来的页面信息。默认的负载均衡采用的是轮询的方式。

如果是用的不同的服务器进行负载均衡的话,只需稍稍改改,就例如如下配置:

upstream mydomain.com{server 47.95.242.167:80; server 47.95.242.168:80; server 47.95.242.169:80;}

配置完之后呢,剩下的在http里的代码和上面的相似,然后在其他的三个服务器那里进行如下配置。当然,我们还得在那三个服务器那里的防火墙进行设置。

server{listen 80; server_name www.mydomain.com; index index.htm index.php index.html; root 目录路径;}

①后端服务器在负载均衡调度中的状态

dowm:当前的server暂时不参与负载均衡。

backup:预留的备份服务器。

max_fails:允许请求失败的次数。

fail_timeout:经过max_fails失败后,服务器暂停的时间。

max_conns:限制最大的接收连接数。

注:以上的配置都是在upstream的时候配置的,例如在{}里面加入的server IP:8001 dowm,就表示这个服务是不参与负载均衡的,用来做备 份的,以上配置都是写在服务的后面。

②调度算法

轮询:按时间顺序逐一分配到不同的后端服务器。

加权轮询:可在配置的server后面加个weight=number,number值越高,分配的概率越大。

ip_hash:每个请求按访问IP的hash分配,这样来自同一IP固定访问一个后台服务器。

least_hash:最少链接数,哪个机器连接数少就发分发给哪个机器。

url_hash:按访问的url的hash结果分配请求,是每个url定向到同一后端服务器上。

hash关键值:hash自定义的key。

注:调度算法在设置upstream中配置,例如在此大括号里面写入ip_hash表示使用ip_hash的方式分配

更多Nginx相关技术文章,请访问Nginx教程栏目进行学习!


# nginx  # 后端  # 负载均衡  # 客户端  # 可在  # 临时文件  # 发送给  # 是在  # 在我  # 自定义  # 越大 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口  怎么用AI帮你设计一套个性化的手机App图标?  Android自定义listview布局实现上拉加载下拉刷新功能  DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解  javascript事件捕获机制【深入分析IE和DOM中的事件模型】  CSS3怎么给轮播图加过渡动画_transition加transform实现【技巧】  大型企业网站制作流程,做网站需要注册公司吗?  Laravel如何与Pusher实现实时通信?(WebSocket示例)  php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】  Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】  nginx修改上传文件大小限制的方法  Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】  Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程  Laravel如何处理CORS跨域请求?(配置示例)  EditPlus中的正则表达式实战(5)  什么是JavaScript解构赋值_解构赋值有哪些实用技巧  如何在 Python 中将列表项按字母顺序编号(a.、b.、c. …)  Laravel Seeder填充数据教程_Laravel模型工厂Factory使用  如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程  如何在阿里云通过域名搭建网站?  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  bing浏览器学术搜索入口_bing学术文献检索地址  android nfc常用标签读取总结  如何在阿里云虚拟服务器快速搭建网站?  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  Laravel DB事务怎么使用_Laravel数据库事务回滚操作  今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】  Linux后台任务运行方法_nohup与&使用技巧【技巧】  Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件  Android使用GridView实现日历的简单功能  佛山企业网站制作公司有哪些,沟通100网上服务官网?  php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】  南京网站制作费用,南京远驱官方网站?  原生JS实现图片轮播切换效果  Android Socket接口实现即时通讯实例代码  Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】  php结合redis实现高并发下的抢购、秒杀功能的实例  如何快速搭建高效WAP手机网站吸引移动用户?  Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用  公司网站制作价格怎么算,公司办个官网需要多少钱?  Laravel如何发送系统通知?(Notification渠道示例)  Laravel如何生成API文档?(Swagger/OpenAPI教程)  如何在IIS7中新建站点?详细步骤解析  java中使用zxing批量生成二维码立牌  制作电商网页,电商供应链怎么做?  如何在景安云服务器上绑定域名并配置虚拟主机?  Laravel如何集成第三方登录_Laravel Socialite实现微信QQ微博登录  浅析上传头像示例及其注意事项  如何快速生成橙子建站落地页链接?