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;
}

 
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可以用这个头做因子,将请求定向到指定的后端;

  

猜你喜欢

转载自www.cnblogs.com/qinxu/p/9709101.html