nginx限流限速

应用场景

下载限速

限制用户下载速度,使用Nginx ngx_http_core_module模块。

请求限制

限制用户一定时间内可以产生的Http请求数,使用Nginx ngx_http_limit_req_module。

连接限制

限制同一时间用户可以产生的连接数及并发数,使用Nginx ngx_http_limit_conn_module。

场景实践

eg1 基于来源IP对下载速率限制,限制每秒处理1次请求,但可以将5个请求放入缓存区。

#基于$binary_remote_addr参数做限制,在内存中开辟一个名为req_one大小为10M的空间来存放每个IP对应的访问频次信息,限制速率为每秒1个请求。
http {
	limit_req_zone $binary_remote_addr zone=req_one:10m rate=1r/s;
}
server	{
	listen 80;
	server_name mirror.atlas.com;
#请求超过1r/s剩下的放入缓存延迟处理,超过burst值后返回503。
	limit_req zone=req_one burst=3 nodelay;
	location / {
	root /code;
	index index.html;
	}
}

eg2 设置共享内存区域和给定键值的最大允许连接数,超过限制返回503。

http {
	limit_conn_zone $binary_remote_addr zone=conn_mg:10m;
}
server	{
	listen 80;
	server_name mirror.atlas.com;
#最多允许两个连接。
	limit_conn conn_mg 2;
	location / {
	root /code;
	index index.html;
	}
}

eg3 限制下载速度。

server	{
	listen 80;
	server_name mirror.atlas.com;
#限制100M后下载速度降到100K。
	limit_rate_after 100m;
	limit_rate 100k;
	location / {
	root /code;
	index index.html;
	}
}

eg4 限制web服务器请求处理速度为1秒1个,触发值为5、限制用户仅可同时下载一个文件。当下载超过100M时限制下载速度为500K。如果同时下载超过2个视频,则返回提示“请充值”。

#在http块中定义请求zone和连接zone的内存区域名称和大小。
http {
	limit_req_zone $binary_remote_addr zone=req_mg:10m rate=1r/s;
	limit_conn_zone $binary_remote_addr zone=conn_mg:10m;
}
server {
	listen 80;
	server_name mirror.oldxu.com;
	root /code;
	charset utf8;
	autoindex on;
	autoindex_exact_size off;
	autoindex_localtime on;
	#限制请求处理速度1秒1个,最多缓存5个请求。
	limit_req zone=req_mg burst=5 nodelay;
	#限制最多1个连接,下载超过100M后限速到500K,超过连接限制返回503时定向到errpage返回请充值。
	limit_conn conn_mg 1;
	limit_rate_after 100m;
	limit_rate 500k;
	error_page 503 @errpage;
	location @errpage {
		default_type text/html;
		return 200 ‘请充值‘;
	}
	location / {
		index index.html;
	}
}

nginx限流限速

上一篇:14最长公共前缀


下一篇:转一个 民科吧 的 帖 : 数学大厦竟如此不堪一击