• 限流设置之Nginx篇


    question1:为什么用到Nginx,Nginx有什么功能?

    1.反向代理(建议先看正向代理,反向代理则是同样你要与对方服务器建立连接,但是,代理服务器和目标服务器在一个LAN下,所以我们需要与代理服务器先建交,再由他获取与目标服务器的交互,好比一个带刀侍卫守护着目标服务器)

    • 屏蔽目标服务器的真实地址,相对安全性较好;
    • nginx的性能好,便于配置负载均衡和动静分离功能,合理利用服务器资源
    • 统一入口,当做负载均衡时,不管目标服务器怎么扩展部署,调用者只访问代理服务器入口即可。
      2.负载均衡(Nginx起到代理作用,在把别人发来的请求转给我们内部服务器时,当我们内部服务器为一个集群时,分活的事就叫负载均衡)
    • RR(轮询):每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
      负载均衡的核心代码为
     upstream test {
      server localhost:8080;
      server localhost:8081;
      }
    
    • 权重(也就是我们来对某一个部署在性能更强的机子上分配更多的活):指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
      upstream test {
       server localhost:8080 weight=9;
       server localhost:8081 weight=1;
       }
    
    • ip_hash:ip_hash的每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
     upstream test {
        ip_hash;
        server localhost:8080;
        server localhost:8081;
        }
    
    • fair(第三方需要额外安装nginx-upstream-fair):按后端服务器的响应时间来分配请求,响应时间短的优先分配。
    upstream backend { 
     fair; 
     server localhost:8080;
     server localhost:8081;
     } 
    
    • url_hash(第三方)按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器
      在upstream中加入hash语句,server语句中不能写入weight等其他的参数(第二种权重),hash_method是使用的hash算法
    upstream backend { 
    hash $request_uri; 
    hash_method crc32; 
    server localhost:8080;
    server localhost:8081;
    } 
    

    3.HTTP服务器(包含动静分离):
    动静分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作,这就是网站静态化处理的核心思路。(也就是把一些常用的不变的静态资源放到nginx中,然后动态变化的资源再由我们内部服务器来提供值)

    upstream test{ 
     server localhost:8080; 
     server localhost:8081; 
     } 
     server { 
     listen 80; 
     server_name localhost; 
     location / { 
     root e:wwwroot; 
     index index.html; 
     } 
     # 所有静态请求都由nginx处理,存放目录为html 
     location ~ .(gif|jpg|jpeg|png|bmp|swf|css|js)$ { 
     root e:wwwroot; 
     } 
     # 所有动态请求都转发给tomcat处理 
     location ~ .(jsp|do)$ { 
     proxy_pass http://test; 
     } 
     error_page 500 502 503 504 /50x.html; 
     location = /50x.html { 
     root e:wwwroot; 
     } 
     } 
    

    4.正向代理(比如VPN,我们自己的电脑与VPN服务器(代理服务器)同处一个LAN下,但是你可能访问不了一些网站(与目标服务器建立不了链接),所以你与你VPN服务器建立连接,让它与你访问不了的网站交流)
    以及根据http状态码配置指定页面、访问权限控制(将访问IP加入到白名单就可以访问,加入到黑名单就不可以访问)
    上图是拒绝指定IP,如果是允许指定IP,可进行如下配置,如下:

    location /weatherforecast/ {
          proxy_pass http://testloadbalance;
          # 这个ip是百度输入ip查看到的,也可以通过nginx日志可以看
          allow 223.88.45.26;    
    }
    

    注:如果在同一location块中同时配置deny和allow,配置在最前面的会覆盖下面的,如下:

    location /weatherforecast/ {
           proxy_pass http://testloadbalance;
           # deny all 放在前面,就所有不能访问,deny all 会覆盖下面配置
           #deny all;
           allow  223.88.45.26;
           # deny all 放在后面,被上面allow进行覆盖
           deny all;    
    }
    

    、适配PC或移动端(本质就是判断请求头中User-Agent,只要匹配到移动端,就去找指定移动页面就行啦。),限流等
    question2:用Nginx来限流的主要思路是什么?
    通过IP限流(为了削峰,即让服务器稳定),主要通过两个方面:1.限制请求速率(限制每个客户端IP地址在规定时间内能够发起的请求次数)2.限制并发连接数(如果只限制请求速率的话,可能会出现同一个IP的用户,频繁调用对应相对耗时的api,也就是利用api的耗时,来在请求速率的限制下,仍然可以影响服务器稳定)
    question3:具体的命令的含义是什么?

    1. 限制请求速率运用了nginx哪个模块?
    2. binary命令起到什么作用?
    3. 限制并发连接数运用了nginx哪个模块?
    4. 限制请求速率运用到了什么算法?IP以及对应的统计数据放在哪里?
    5. 为什么存储空间选择10M,大概能存多少IP?

    1ngx_http_limit_req_module
    2压缩的作用
    3ngx_http_limit_conn_module
    4漏桶算法,放nginx中,zone=xxx:10M也就是声明了对应的空间
    5存储空间需要根据应用用户量,大概10M==160000Ip

    引用学习资料来自:
    【Java项目亮点第四期:三层限流设计】 https://www.bilibili.com/video/BV1y6421G725/?share_source=copy_web&vd_source=d893458c5ff2a94c6b7cb079e1cfcdb9
    http://t.csdnimg.cn/SVj0X
    https://zhuanlan.zhihu.com/p/373138496


    __EOF__

  • 本文作者: 海山了
  • 本文链接: https://www.cnblogs.com/seamount3/p/18006995
  • 关于博主: 评论和私信会在第一时间回复。或者直接私信我。
  • 版权声明: 本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
  • 声援博主: 如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。
  • 相关阅读:
    [游戏开发][unity]Xlua中使用proto、json、lpeg
    由于没有远程桌面授权服务器可以提供许可证,远程会话连接已断开
    dpdk hw-offload flows i
    一.node的http模块;二.同步和异步;三.异步操作的实现:ajax;四.jQuery中对ajax封装;五.Node的Web框架
    【Linux】20、进程状态:不可中断进程、iowait、僵尸进程、dstat strace pstree
    C++的结构体
    面试经典150题——Day22
    代码最佳实践和指南(一)
    【Hello Go】Go语言工程管理
    vue实现stompjs+websocket和后端通信(二)
  • 原文地址:https://www.cnblogs.com/seamount3/p/18006995