Nginx 流量控制
在流量控制方面, Nginx 主要提供了ngx_http_limit_conn_module 和ngx_http_limit_req_module 两种模块来完成这样的功能。
ngx_http_limit_conn_module 模块: 主要针对连接数的配置
ngx_http_limit_req_module 模块: 主要针对请求并发量的控制
1、ngx_http_limit_conn_module 模块配置实例
1)添加配置
# 在http 段上设置一个共享区间(只能在http段上设置), 在这个共享区间中会以
$binary_remote_addr 为key,
# 去记录每个客户端的连接情况
limit_conn_zone $binary_remote_addr zone=addr:20m;
# 设置每个客户端的连接最大数为10, 当超过最大限制后,将返回error
# 可以设置在http段 、server段、location 段
#
limit_conn addr 10;
# 超过最大限制后, 返回的error状态码。 默认不设置也为 503
limit_conn_status 503;
limit_conn_zone $binary_remote_addr zone=addr:20m;
server {
listen 80;:
server_name cdn.qfedu.com;
root /data0/www/htdocs/cdn.qfedu.com;
access_log /data0/www/logs/cdn.qfedu.com-access_log main;
error_log /data0/www/logs/cdn.qfedu.com-error_log;
limit_conn addr 10;
limit_conn_status 503;
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ {
expires 1d;
}
location ~ .*\.(js|css)?$ {
expires 1d;
}
}
2)压测验证
# 发起1000个请求,每次并发10个请求。基本发现不了连接次数超限的情况
# ab -n 1000 -c 10 http://cdn.qfedu.com/test.css
# 压力测试的同事,观察访问日志的状态码
# tail -f cdn.qfedu.com-access_log | awk '$8 > 500 {print}'
# 发起1000个请求,每次并发11个请求的时候已经存在连接次数超限的情况
# ab -n 1000 -c 11 http://cdn.qfedu.com/test.css
# tail -f cdn.qfedu.com-access_log | awk '$8 > 500 {print}'
cdn.qfedu.com [21/Mar/2018:23:44:43 +0800] "GET /test.css HTTP/1.0" 89 503 206
0.006 "-" "Apache