最近常常用人帮忙作压力测试,用webbech或者ab等一些工具模拟并发压服务器,若服务器没有限制链接数或带宽,服务器很容易被压跨。
cat nginx.conf
…
http {
…
limit_conn_zone $binary_remote_addr zone=one:10m;
#若是在1.1.8以后版本还用语法:limit_zone name $variable size,会报警告nginx: [warn] the
“limit_zone” directive is deprecated, use the “limit_conn_zone”
directivenginx
#这里,设置客户端的IP地址做为键。注意,这里使用的是$binary_remote_addr变量,而不是$remote_addr变
量。$remote_addr变量的长度为7字节到15字节不等,而存储状态在32位平台中占用32字节或64字节,在64位平台中占用64字节。
而$binary_remote_addr变量的长度是固定的4字节,存储状态在32位平台中占用32字节或64字节,在64位平台中占用64字节。一兆
字节的共享内存空间能够保存3.2万个32位的状态,1.6万个64位的状态。若是共享内存空间被耗尽,服务器将会对后续全部的请求返回 503
(Service Temporarily Unavailable) 错误。web
server {
limit_conn one 10;
#指定一个会话最大的并发链接数(与以前的limit_conn_zone配合使用),可对单独目录作出限制,一个IP只能发起10个链接,多于10个,一概返回Services unavailable(503)状态,生产环境需考虑办公室或者局域网共享IP问题
limit_rate_after 1m;
#设置单链接限速条件(当下载文件字节数超过1MB后,limit_rate限速生效,限速100k)
limit_rate 100k;
#单链接限速
…
}
…
}服务器