nginx的负载均衡
负载均衡
1. 什么是负载均衡
负载均衡建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。
通俗理解就是把发送的请求分发到不同服务器来处理请求并响应,如图:请求到达nginx,由nginx分发请求到哪一台应用服务器来处理请求,这就是一个负载的过程
2. upstream的调度方式
负载使用到的就是这个模块,通过这个模块nginx能够按照你所需要的调度规则去分发请求,在这里简单介绍一下四种调度方式
- 轮询(默认):每个请求按时间顺序逐一分配到不同的后端服务器;
- ip_hash:每个请求按访问IP的hash结果分配,同一个IP客户端固定访问一个后端服务器。可以保证来自同一ip的请求被打到固定的机器上,可以解决session问题。
- url_hash:按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器。后台服务器为缓存的时候效率。
- fair:这是比上面两个更加智能的负载均衡算法。此种算法可以依据页面大小和加载时间长短智能地进行负载均衡,也就是根据后端服务器的响应时间来分配请求,响应时间短的优先分配。Nginx本身是不支持 fair的,如果需要使用这种调度算法,必须下载Nginx的 upstream_fair模块。
3. 默认的调度方式(实例)
我们用最简单的默认的调度方式来配置一下简单负载
-
打开nginx的nginx.conf。配置文件,找到正在监听80端口的server,在server上方添加一个upstream为tomcat,权重为1:1,也就是各50%
upstream tomcat { server 127.17.0.2:8080 weight=1; server 127.17.0.3:8080 weight=1; }
-
在server中的localtion中去掉原有的静态文件配置,并配置代理
location / { proxy_pass http://tomcat; }
-
接下来就是重启nginx
#在nginx根目录 ./sbin/nginx -s reload
-
验证
验证的方式有很多种,这里为了方便我就直接在日志里验证这个负载的是否成功了,我在配置文件中打开了访问日志,并添加$upstream_addr:后端服务器的IP地址
接下来我们来查看日志
我请求了12次,查看日志之后发现分配的很均匀,各50%
由此我知道,配置成功了
至此,一个简单的负载功能完成,如果你要改变调度的权重,只需要修改upstream里面weight值,如果要修改调度方式,也只用修改upstream,只是方式略有不同,这里暂时先不一一介绍,后期再更新吧
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库