nginx反向代理和负载均衡详解程序员
最近由于公司的业务增长 服务器承受不住压力经常出现崩溃现象 为了解决 使用nginx的负载均衡解决,以下是操作步骤:
1.nginx 的负载均衡:将压力分散到不同的机器上
nginx不单可以作为强大的web服务器,也可以作为一个反向代理服务器,而且nginx还可以按照调度规则实现动态、静态页面的分离,可以按照轮询、ip哈希、URL哈希、权重等多种方式对后端服务器做负载均衡,同时还支持后端服务器的健康检查
2.nginx负载均衡配置:
修改配置文件中的proxy_pass和添加upstream
upstream www.test.com server 192.168.1.1:8080; server 192.168.1.2:8080;
proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; }
nginx 的 upstream目前支持 4 种方式的分配
1)、轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
2)、weight
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
2)、ip_hash
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
3)、fair(第三方)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
4)、url_hash(第三方)
3.nginx多台机器session共享
ip_hash
nginx中的ip_hash技术能够将某个ip的请求定向到同一台后端,这个ip下的某个客户端和某个后端就能建立起稳固的session,ip_hash是在upstream配置中定义的:
upstream backend { server 127.0.0.1:8001; server 127.0.0.1:8002; ip_hash; }
1)ip_hash缺陷:
nginx不是最前端的服务器,ip_hash要求nginx一定是最前端的服务器,否则nginx得不到正确ip,就不能根据ip作hash;如使用的是squid为最前端,那么nginx取ip时只能得到squid的服务器ip地址,用这个地址来作分流是肯定错乱的
nginx的后端其它方式的负载均衡:将请求通过另外的方式分流,那么某个客户端的请求肯定不能定位到同一台session应用服务器上,nginx后端只能直接指向应用服务器,或者再搭一个squid,然后指向应用服务器;
最好的办法是用location作一次分流,将需要session的部分请求通过ip_hash分流,剩下的走其它后端去
2)upstream_hash 第三方模块
这个模块多数情况下是用作url_hash的,但是并不妨碍将它用来做session共享,如前端是squid,它会将ip加入x_forwarded_for这个http_header里,用upstream_hash可以用这个头做因子,将请求定向到指定的后端;
原创文章,作者:Maggie-Hunter,如若转载,请注明出处:https://blog.ytso.com/1510.html
服务器部署程序员系统优化网站设置运维相关文章
- Apache负载均衡配置(反向代理模式)
- Dubbo 负载均衡策略和集群容错策略都有哪些?动态代理策略呢?
- Java 动态代理的两种方式及其优缺点
- Nginx正向代理、反向代理、负载均衡
- 关于Spring的两三事:代理对象的生成时机
- 一篇带你搞懂Nginx命令、配置、反向代理、负载均衡
- 【设计模式】代理模式 ( 动态代理 )
- nginx反向代理+缓存开启+url重写+负载均衡(带健康探测)的部署记录详解程序员
- Linux下的代理软件:解决网络连接问题(代理软件linux)
- Mybatis学习总结(二):Mapper代理开发详解编程语言
- Kong 1.3 发布:原生 gRPC 代理、上游 TLS 交叉认证
- Linux实现反向代理的秘密(linux反向代理)
- Nginx高性能Web服务器:Nginx HTTP负载均衡和反向代理的配置与优化(第六章)
- Linux环境下透明代理无障碍上网(linux透明代理)
- 如何在 Linux 上 设置网络代理(linux设置网络代理)
- 借助Redis和Nginx进行更有效的负载均衡(redis配合nginx)
- nginx作为反向代理实现负载均衡的例子