搜索
首页运维Nginxnginx怎么负载均衡

nginx怎么负载均衡

Jun 20, 2019 pm 03:47 PM
nginx负载均衡

nginx怎么负载均衡

一、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的端口是事先在配置文件里配置好的。例如如下的配置。

1.jpg

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

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

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怎么负载均衡的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
NGINX:现代Web应用程序的多功能工具NGINX:现代Web应用程序的多功能工具Apr 11, 2025 am 12:03 AM

NGINXisessentialformodernwebapplicationsduetoitsrolesasareverseproxy,loadbalancer,andwebserver,offeringhighperformanceandscalability.1)Itactsasareverseproxy,enhancingsecurityandperformancebycachingandloadbalancing.2)NGINXsupportsvariousloadbalancingm

NGINX SSL/TLS配置:使用HTTPS确保您的网站NGINX SSL/TLS配置:使用HTTPS确保您的网站Apr 10, 2025 am 09:38 AM

通过Nginx配置SSL/TLS来确保网站安全,需要以下步骤:1.创建基本配置,指定SSL证书和私钥;2.优化配置,启用HTTP/2和OCSPStapling;3.调试常见错误,如证书路径和加密套件问题;4.应用性能优化建议,如使用Let'sEncrypt和会话复用。

NGINX面试问题:ACE您的DevOps/System Admin面试NGINX面试问题:ACE您的DevOps/System Admin面试Apr 09, 2025 am 12:14 AM

Nginx是高性能的HTTP和反向代理服务器,擅长处理高并发连接。1)基本配置:监听端口并提供静态文件服务。2)高级配置:实现反向代理和负载均衡。3)调试技巧:检查错误日志和测试配置文件。4)性能优化:启用Gzip压缩和调整缓存策略。

NGINX缓存技术:改善网站性能NGINX缓存技术:改善网站性能Apr 08, 2025 am 12:18 AM

Nginx缓存可以通过以下步骤显着提升网站性能:1)定义缓存区和设置缓存路径;2)配置缓存有效期;3)根据不同内容设置不同的缓存策略;4)优化缓存存储和负载均衡;5)监控和调试缓存效果。通过这些方法,Nginx缓存能减少后端服务器压力,提升响应速度和用户体验。

带Docker的NGINX:部署和缩放容器化应用程序带Docker的NGINX:部署和缩放容器化应用程序Apr 07, 2025 am 12:08 AM

使用DockerCompose可以简化Nginx的部署和管理,通过DockerSwarm或Kubernetes进行扩展是常见的做法。1)使用DockerCompose定义和运行Nginx容器,2)通过DockerSwarm或Kubernetes实现集群管理和自动扩展。

高级NGINX配置:掌握服务器块和反向代理高级NGINX配置:掌握服务器块和反向代理Apr 06, 2025 am 12:05 AM

Nginx的高级配置可以通过服务器块和反向代理实现:1.服务器块允许在一个实例中运行多个网站,每个块独立配置。2.反向代理将请求转发到后端服务器,实现负载均衡和缓存加速。

NGINX性能调整:针对速度和低潜伏期进行优化NGINX性能调整:针对速度和低潜伏期进行优化Apr 05, 2025 am 12:08 AM

Nginx性能调优可以通过调整worker进程数、连接池大小、启用Gzip压缩和HTTP/2协议、使用缓存和负载均衡来实现。1.调整worker进程数和连接池大小:worker_processesauto;events{worker_connections1024;}。2.启用Gzip压缩和HTTP/2协议:http{gzipon;server{listen443sslhttp2;}}。3.使用缓存优化:http{proxy_cache_path/path/to/cachelevels=1:2k

NGINX安全性硬化:保护您的Web服务器免受攻击NGINX安全性硬化:保护您的Web服务器免受攻击Apr 04, 2025 am 12:06 AM

Nginx安全强化可以通过以下步骤实现:1)确保所有流量通过HTTPS传输,2)配置HTTP头增强通信安全性,3)设置SSL/TLS加密数据传输,4)实施访问控制和速率限制防范恶意流量,5)使用ngx_http_secure_link_module模块防范SQL注入攻击,这些措施能有效提升Nginx服务器的安全性。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具