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

      

  • 相关阅读:
    写时复制集合 —— CopyOnWriteArrayList 源码原理阅读笔记
    初步整合vue-element-admin和GitDataV两个Vue开源框架方案实现大数据可视化
    IOS苹果登录sign in with apple后端校验
    IOS审核被拒:IOS苹果授权登录(Sign in with Apple)/Apple登录/苹果登录集成教程
    ios安装自定义基座失败问题
    IOS APP上架App Store及提交审核详细教程
    IOS APP报错:SyntaxError: Invalid regular expression: invalid group specifier name __ERROR
    Apple Pay苹果支付IOS in-App Purchase内购项目服务端校验
    浅析浏览器是如何工作的(一):V8引擎、JIT机制、JS代码解释执行与编译执行
    ApplePay苹果支付内购项目配置及代码实现及沙箱测试
  • 原文地址:https://www.cnblogs.com/qinxu/p/9709101.html
Copyright © 2020-2023  润新知