Nginx 连接限制和访问控制Nginx 连接限制和访问控制
Nginx 连接限制和访问控制
前言
Nginx
自带的模块支持对并发请求数进行限制, 还有对请求来源进行限制。可以用来防止DDOS
攻击。
阅读本文须知道nginx
的配置文件结构和语法。
连接限制 limit_conn_module
limit_conn_module
: TCP
连接频率限制, 一次TCP
连接可以建立多次HTTP
请求。
配置语法:
limit_conn_module 语法 |
范围 | 说明 |
---|---|---|
limit_conn_zone 标识 zone=空间名:空间大小; |
http |
用于声明一个存储空间 |
limit_conn 空间名 并发限制数; |
http 、server 或location |
用于限制某个存储空间的并发数量 |
limit_conn_log_level 日志等级; |
http 、server 或location |
当达到最大限制连接数后, 记录日志的等级 |
limit_conn_status 状态码; |
http 、server 或location |
当超过限制后,返回的响应状态码,默认是503 |
limit_conn_zone
会声明一个zone
空间来记录连接状态, 才能限制数量。zone
是存储连接状态的空间, 以键值对存储, 通常以客户端地址$binary_remote_addr
作为key
来标识每一个连接。
当zone
空间被耗尽,服务器将会对后续所有的请求返回503(Service Temporarily Unavailable)
错误。
请求限制 limit_req_mudule
limit_req_mudule
: HTTP
请求频率限制, 一次TCP
连接可以建立多次HTTP
请求。
配置语法:
limit_req_mudule 语法 |
范围 | 说明 |
---|---|---|
limit_req_zone key zone=空间名:空间大小 rate=每秒请求数; |
http |
用于声明一个存储空间 |
limit_req zone=空间名 [burst=队列数] [nodelay]; |
http 、server 或location |
用于限制某个存储空间的并发数量 |
这里的zone
也是用来存储连接的一个空间。
burst 和 nodelay
burst
和nodelay
对并发请求设置了一个缓冲区和是否延迟处理的策略。
先假设有如下zone
配置。
1 |
http { |
情况 1: limit_req zone=req_zone;
- 第
1
秒发送10
个请求, 正常响应。 - 第
1
秒发送13
个请求, 前10
个请求正常响应, 后3
个请求返回503(Service Temporarily Unavailable)
。
不加brust
和nodelay
的情况下, rate=10r/s
每秒只能执行10
次请求, 多的直接返回503
错误。
情况 2: limit_req zone=req_zone brust=5;
- 第
1
秒发送10
个请求, 正常响应。 - 第
1
秒发送13
个请求, 前10
个请求正常响应, 后3
个请求放入brust
等待响应。 - 第
1
秒发送20
个请求, 前10
个请求正常响应, 后5
个请求放入brust
等待响应, 最后5
个请求返回503(Service Temporarily Unavailable)
, 第2
秒执行brust
中的5
个请求。 - 第
1
秒发送20
个请求, 前10
个请求正常响应, 后5
个请求放入brust
等待响应, 最后5
个请求返回503(Service Temporarily Unavailable)
, 第2
秒发送6
个请求, 执行brust
中的5
个请求, 将5
个请求放入brust
等待响应, 剩下的1
个请求返回503(Service Temporarily Unavailable)
。
加brust=5
不加nodelay
的情况下, 有一个容量为5
的缓冲区, rate=10r/s
每秒只能执行10
次请求, 多的放到缓冲区中, 如果缓冲区满了, 就直接返回503
错误。而缓冲区在下一个时间段会取出请求进行响应, 如果还有请求进来, 则继续放缓冲区, 多的就返回503
错误。
情况 3: limit_req zone=req_zone brust=5 nodelay;
- 第
1
秒发送10
个请求, 正常响应。 - 第
1
秒发送13
个请求,13
个请求正常响应。 - 第
1
秒发送20
个请求, 前15
个请求正常响应, 后5
个请求返回503(Service Temporarily Unavailable)
。 - 第
1
秒发送20
个请求, 前15
个请求正常响应, 后5
个请求返回503(Service Temporarily Unavailable)
, 第2
秒发送6
个请求, 正常响应。
加brust=5
和nodelay
的情况下, 有一个容量为5
的缓冲区, rate=10r/s
每秒能执行15
次请求, 15=10+5
。多的直接返回503
错误。
基于 IP 的访问控制
http_access_module
: 基于IP
的访问控制, 通过代理可以绕过限制, 防君子不防小人。
http_access_module 语法 |
范围 | 说明 |
---|---|---|
allow IP地址 | CIDR网段 | unix: | all; |
http 、server 、location 和limit_except |
允许IP地址 、CIDR 格式的网段、unix 套接字或所有来源访问 |
deny IP地址 | CIDR网段 | unix: | all; |
http 、server 、location 和limit_except |
禁止IP地址 、CIDR 格式的网段、unix 套接字或所有来源访问 |
allow
和deny
会按照顺序, 从上往下, 找到第一个匹配规则, 判断是否允许访问, 所以一般把all
放最后。
1 |
location / { |
基于用户密码的访问控制
http_auth_basic_module
: 基于文件匹配用户密码的登录
http_auth_basic_module 语法 |
范围 | 说明 |
---|---|---|
auth_basic 请输入你的帐号密码 | off; |
http 、server 、location 和limit_except |
显示用户登录提示 (有些浏览器不显示提示) |
auth_basic_user_file 存储帐号密码的文件路径; |
http 、server 、location 和limit_except |
从文件中匹配帐号密码 |
密码文件可以通过htpasswd
生成, htpasswd
需要安装yum install -y httpd-tools
。
1 |
# -c 创建新文件, -b在参数中直接输入密码 |
参考资料
Nginx 连接限制和访问控制Nginx 连接限制和访问控制的更多相关文章
- 基于Nginx实现访问控制、连接限制
0 前言 Nginx自带的模块支持对并发请求数进行限制, 还有对请求来源进行限制.可以用来防止DDOS攻击.阅读本文须知道nginx的配置文件结构和语法. 1. 默认配置语法 nginx.conf作为 ...
- NGINX轻松管理10万长连接 --- 基于2GB内存的CentOS 6.5 x86-64
http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=190176&id=4234854 一 前言 当管理大量连接时,特别 ...
- NGINX轻松管理10万长连接
先说说服务为什么使用HTTPs长连接技术?有如下几个原因:对响应时间要求较高:服务走的是公网,客户端与服务端的TCP建立的三次握手和断开的四次握手都需要40ms左右(真实数据包计算出来的),共需要80 ...
- nginx和apache最核心的区别在于apache是同步多进程模型,一个连接对应一个进程;nginx是异步的,多个连接(万级别)可以对应一个进程
nginx和apache的一些优缺点比较,摘自网络,加自己的一些整理. nginx相对于apache的优点: 1.轻量级,同样是web 服务,比apache 占用更少的内存及资源 2.抗并发,ngin ...
- nginx与apache 对比 apache是同步多进程模型,一个连接对应一个进程;nginx是异步的,多个连接(万级别)可以对应一个进程
nginx与apache详细性能对比 http://m.blog.csdn.net/lengzijian/article/details/7699444 http://www.cnblogs.com/ ...
- nginx反向代理时保持长连接
·[场景描述] HTTP1.1之后,HTTP协议支持持久连接,也就是长连接,优点在于在一个TCP连接上可以传送多个HTTP请求和响应,减少了建立和关闭连接的消耗和延迟. 如果我们使用了nginx去作为 ...
- Nginx实践篇(5)- Nginx代理服务 - 代理缓冲区、代理重新定义请求头、代理连接超时(转)
Nginx实践篇(5)- Nginx代理服务 - 代理缓冲区.代理重新定义请求头.代理连接超时 nginx参数默认值 http://nginx.org/en/docs/http/ngx_http_co ...
- Nginx解析漏洞复现以及哥斯拉连接Webshell实践
Nginx解析漏洞复现以及哥斯拉连接Webshell实践 目录 1. 环境 2. 过程 2.1 vulhub镜像拉取 2.2 漏洞利用 2.3 webshell上传 2.4 哥斯拉Webshell连接 ...
- Nginx详解九:Nginx基础篇之Nginx的访问控制
基于IP的访问控制:http_access_module 不允许指定网段的用户访问:配置语法:deny address | CIDR | unix: | all;默认状态:-配置方法:http.ser ...
随机推荐
- 微信小程序 Echarts 异步数据更新
微信小程序 Echarts 异步数据更新的练习,被坑了很多次,特作记录. 作者:罗兵 地址:https://www.cnblogs.com/hhh5460/p/9989805.html 0.效果图 ...
- vs编译器好多下划波浪线但不报错
解决办法:项目属性->c/c++->常规->附加包含目录->$(ProjectDir): $(ProjectDir) 项目的目录(定义形式:驱动器 + 路径):包括尾部的反斜杠 ...
- JQuery快速入门-选择器
JQuery选择器 JQuery 选择器继承了CSS 与Path 语言的部分语法,允许通过标签名.属性名或内容对DOM 元素进行快速.准确的选择,而不必担心浏览器的兼容性,通过jQuery 选择器对页 ...
- Asp.Net_后台代码访问前台html标签
//单击按钮后批量改变li元素的内联文本值及样式 ; i <= ; i++) { HtmlGenericControl li = this.FindControl("li" ...
- jmeter实战1
- 开发认为不是bug,你该如何处理?
这是软件测试员面试时经常被问到的问题.看了很多答案,个人觉得作为有工作经验的测试人员回答时不能完全照搬标准答案,技术面试官想听的当然不止如此.毕竟这种情况在实际工作中也常常出现,具体问题要具体分析,你 ...
- LazyBug环境部署
前言: LazyBug(授权协议:GPL)是一款PHP编写的开源HTTP接口测试管理系统,它集成了接口的测试.管理.维护.自动化回归等一系列工作,以实现对测试效率和管理效率的提高. 本次教程仅支持Wi ...
- #个人博客作业Week1----关于软件和软件工程的出现
1.软件工程这个词如何出现的? 数学与电脑科学先锋Margaret Hamilton在开发阿波罗11号软件的期间发明的,目的是将软件与硬件还有其他工程学类做出区别,为软件以及那些发明者争取应有的正统性 ...
- CSS——【元素内边距padding、元素外边距margin、元素边框border-width、元素大小width/height】与【元素显示大小】的关系
一.基本知识 padding:元素内边距,指的是元素内边框到元素中内容的距离. 用法: padding:长度|百分比 padding-top:长度|百分比 padding-bottom:长度|百分比 ...
- 冲刺Two之站立会议4
在完成了对主界面的设计之后,我们对自己的聊天室界面进行了优化,添加了一些标签和图片按钮等组件让界面更加美观一些.然后还查询了一些关于改进视频和音频质量的资料,准备开展相关工作.