博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
nginx ------反向代理和负载均衡
阅读量:5065 次
发布时间:2019-06-12

本文共 1727 字,大约阅读时间需要 5 分钟。

最近由于公司的业务增长 服务器承受不住压力经常出现崩溃现象 为了解决 使用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;} server{    listen  80;    server_name  blog.test.com wode.test.com;     location / {        proxy_pass        http://www.test.com;        proxy_set_header   Host             $host;        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可以用这个头做因子,将请求定向到指定的后端;

  

posted on
2018-09-27 11:04 阅读(
...) 评论(
...)

转载于:https://www.cnblogs.com/qinxu/p/9709101.html

你可能感兴趣的文章
【剑指offer】面试题43:n个骰子的点数
查看>>
一些常被你忽略的CSS小知识
查看>>
Hibernate----Hibernate小配置
查看>>
C#实现无限层级树
查看>>
C# ASP.NET MVC HtmlHelper用法大全
查看>>
HDOJ acm steps 3.1.1
查看>>
vue+element+echarts柱状图+列表
查看>>
JMS ActiveMQ案例
查看>>
Android简化xml sax解析
查看>>
POJ 2763 Housewife Wind
查看>>
第8章 线性时间排序
查看>>
C语言中一个语句太长用什么换行?
查看>>
SQL with(unlock)与with(readpast) (转)
查看>>
什么是长尾理论
查看>>
html5-6 Frame框架窗口类型
查看>>
新东方雅思词汇---6.1、oppose
查看>>
DFS序
查看>>
js进阶ajax函数封装(匿名函数作为参数传递)(封装函数引入文件的方式非常好用)...
查看>>
tomcat服务器安装
查看>>
SQL中的long text
查看>>