博客
关于我
Nginx配置限流限连接示例及相关知识汇总
阅读量:172 次
发布时间:2019-02-28

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

目录


*Nginx与Tomcat配置

属性

Nginx

Tomcat

版本

1.14.2

Tomcat7

主机

192.168.1.XXX

192.168.1.XXX

端口

18080

8080

项目名称

xht

xht

 

Nginx初始化限流20MB

模板一

 

http{

#限流20MB

#limit_conn_zone $binary_remote_addr zone=one:20m;

 

    #限流20MB,每秒允许处理1000个请求

limit_req_zone $binary_remote_addr zone=perip:20m rate=1000r/s;

server {

location /xht {

root html;

index index.html index.htm;

limit_req zone=perip;

proxy_pass http://192.168.1.111:8080/xht;

}

}

 

}

模板二

http {

    # 总限流20MB 1000次/秒

limit_req_zone $binary_remote_addr zone=totalLimit:20m rate=1000r/s;

# 设置5MB用于图片上传,限制连接个数

limit_conn_zone $binary_remote_addr zone=uploadLimit:5m;

server {

location /xht {

root html;

index index.html index.htm;

#总流量限制和突发限制

limit_req zone=totalLimit burst=1000 nodelay;

proxy_pass http://192.168.1.111:8080/xht;

}

# 附件上传

location /uploadAttach.do{

    # 限制每个IP只允许1个并发连接

    limit_conn uploadLimit 1;

    # 每个连接上传流量限制

limit_rate  1024k;

}

}

}

模板三

http {

    # 总限流20MB 1000次/秒

limit_req_zone $binary_remote_addr zone=totalLimit:20m rate=1000r/s;

# 设置5MB用于图片上传,限制连接个数

limit_conn_zone $binary_remote_addr zone=uploadLimit:5m;

# 设置10MB用于高频接口,每秒请求频率

limit_req_zone $binary_remote_addr zone=feqLimit:10m rate=100r/s;

server {

location /xht {

root html;

index index.html index.htm;

#总流量限制和突发限制

limit_req zone=totalLimit burst=1000 nodelay;

proxy_pass http://192.168.1.111:8080/xht;

}

# 附件上传

location /uploadAttach.do{

    # 限制每个IP只允许1个并发连接

    limit_conn uploadLimit 1;

    # 每个连接上传流量限制

limit_rate  512k;

}

 

# 登录

location /userLogin.do {

limit_req zone=feqLimit burst=100;

}

# 实时位置

location /sendXhyPos.do {

limit_req zone=feqLimit burst=100;

}

 

# 通知公告

location /getMessage.do {

limit_req zone=feqLimit burst=100;

}

 

}

}

 

*Nginx文件上传设置

5MB

http {

# 设置5MB用于图片上传,限制连接个数

limit_conn_zone $binary_remote_addr zone=uploadLimit:5m;

server {

location /xht {

root html;

index index.html index.htm;

proxy_pass http://192.168.1.111:8080/xht;

}

location /uploadAttach.do {

    # 限制每个IP只允许1个并发连接

    limit_conn uploadLimit 1;

    # 每个连接上传流量限制

limit_rate  512k;

}

}

}

 

 

10MB

http {

# 设置10MB用于图片上传,限制连接个数

limit_conn_zone $binary_remote_addr zone=uploadLimit:10m;

server {

location /xht {

root html;

index index.html index.htm;

proxy_pass http://192.168.1.111:8080/xht;

}

location /uploadAttach.do {

    # 限制每个IP只允许1个并发连接

    limit_conn uploadLimit 1;

    # 每个连接上传流量限制

limit_rate  512k;

}

}

}

 

15MB

http {

# 设置15MB用于图片上传,限制连接个数

limit_conn_zone $binary_remote_addr zone=uploadLimit:15m;

server {

location /xht {

root html;

index index.html index.htm;

proxy_pass http://192.168.1.111:8080/xht;

}

location /uploadAttach.do {

    # 限制每个IP只允许1个并发连接

    limit_conn uploadLimit 1;

    # 每个连接上传流量限制

limit_rate  512k;

}

}

}

 

18MB

http {

# 设置18MB用于图片上传,限制连接个数

limit_conn_zone $binary_remote_addr zone=uploadLimit:18m;

server {

location /xht {

root html;

index index.html index.htm;

proxy_pass http://192.168.1.111:8080/xht;

}

location /uploadAttach.do {

    # 限制每个IP只允许1个并发连接

    limit_conn uploadLimit 1;

    # 每个连接上传流量限制

limit_rate  512k;

}

}

}

 

*Nginx高频接口配置[登录、实时位置、通知公告]

50r/s

http {

limit_req_zone $binary_remote_addr zone=feqLimit:20m rate=50r/s;

server {

location /xht {

root html;

index index.html index.htm;

proxy_pass http://192.168.1.111:8080/xht;

}

# 后台登录

location /login_gis/loginVerify.do {

limit_req zone=feqLimit burst=50;

}

# 移动端登录

location /userLogin.do {

limit_req zone=feqLimit burst=50;

}

 

# 实时位置

location /sendXhyPos.do {

limit_req zone=feqLimit burst=50;

}

 

# 通知公告

location /getMessage.do {

limit_req zone=feqLimit burst=50;

}

 

}

}

100r/s

http {

limit_req_zone $binary_remote_addr zone=feqLimit:20m rate=100r/s;

server {

location /xht {

root html;

index index.html index.htm;

proxy_pass http://192.168.1.111:8080/xht;

}

# 后台登录

location /login_gis/loginVerify.do {

limit_req zone=feqLimit burst=100;

}

# 移动端登录

location /userLogin.do {

limit_req zone=feqLimit burst=100;

}

# 实时位置

location /sendXhyPos.do {

limit_req zone=feqLimit burst=100;

}

 

# 通知公告

location /getMessage.do {

limit_req zone=feqLimit burst=100;

}

 

}

}

 

150r/s

http {

limit_req_zone $binary_remote_addr zone=feqLimit:20m rate=150r/s;

server {

location /xht {

root html;

index index.html index.htm;

proxy_pass http://192.168.1.111:8080/xht;

}

# 后台登录

location /login_gis/loginVerify.do {

limit_req zone=feqLimit burst=150;

}

# 移动端登录

location /userLogin.do {

limit_req zone=feqLimit burst=150;

}

# 实时位置

location /sendXhyPos.do {

limit_req zone=feqLimit burst=150;

}

 

# 通知公告

location /getMessage.do {

limit_req zone=feqLimit burst=150;

}

 

}

}

 

200r/s

http{

limit_req_zone $binary_remote_addr zone=feqLimit:20m rate=200r/s;

server {

location /xht {

root html;

index index.html index.htm;

proxy_pass http://192.168.1.111:8080/xht;

}

# 后台登录

location /login_gis/loginVerify.do {

limit_req zone=feqLimit burst=200;

}

# 移动端登录

location /userLogin.do {

limit_req zone=feqLimit burst=200;

}

# 实时位置

location /sendXhyPos.do {

limit_req zone=feqLimit burst=200;

}

 

# 通知公告

location /getMessage.do {

limit_req zone=feqLimit burst=200;

}

 

}

 

}

参考资料

网文参考

 

 

 

 

 

Nginx官文

 

 

 

 

限连:客户端连接限速

参考:

 

http {

#容器共使用10M的来对于IP传输开销 

  limit_conn_zone $binary_remote_addr zone=one:10m; 

server {

    location /download/ {

      limit_conn   one  1;  #限制每个IP只能发起一个并发连接

      limit_rate 300k;   #对每个连接限速300k。   

}

  }

}

#注意,这里是对连接限速,而不是对IP限速。

#如果一个IP允许两个并发连接,那么这个IP就是限速limit_rate×2。

 

限流:客户端请求的处理速率

 

http {

    limit_req_zone $ binary_remote_addr zone = one:10m rate = 1r/s;

    server{

        location /upload/{

            limit_req zone= one burst = 5;

     }

}

 

 

转载地址:http://vexj.baihongyu.com/

你可能感兴趣的文章
ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
查看>>
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>