在http节点中添加
# 创建限流规则 limit_req_zone $binary_remote_addr zone=addr:10m rate=1r/s;# 客户端进行限流 # limit_req_zone $server_name zone=addr:10m rate=1r/s; # 服务端进行限流 server { # 监听端口默认是80 listen 80; # 服务器ip或域名 server_name 192.168.140.130; location / { limit_req zone=addr burst=1 nodelay; proxy_pass http://xiaohemiao; } } upstream xiaohemiao { server 192.168.140.130:7777; # 应用端口7777 server 192.168.140.130:8888; # 应用端口8888 }
比如只对登录进行限流,假设登录接口名为login
location = /login { limit_req zone=addr burst=1 nodelay; proxy_pass http://xiaohemiao; }
在配置中需要注意的一点是location匹配规则和优先级
= 开头表示精确匹配
^~ 开头表示url以某个常规字符串开头,不是正则匹配
~ 表示区分大小写的匹配
~* 开头表示不区分大小写的正则匹配
/ 通配匹配,如果没有其他匹配,任何请求都会匹配到