kong插件之Rate Limiting
来源:互联网 发布:上海市软件著作权资助 编辑:程序博客网 时间:2024/05/24 04:25
文章来源:http://blog.csdn.net/qq_26656329/article/details/78842005
关于Response Rate Limiting插件
说明
插件实现是在每个代理upstream API之前添加header信息,以便正确的拒绝处理该请求;
插件启用的时候,响应时会告诉客户端可以请求多少次、有多少次请求可以用;
比如:
X-RateLimit-Limit-Videos-Minute: 10X-RateLimit-Remaining-Videos-Minute: 9
如果有多种限制组合,则返回更多的限制组合
Rate Limiting插件常用参数
尽量把每个参数都测试一遍
name:插件名称,必选参数,每月默认值;consumer_id:消费者id,可选参数,没有默认值,如果留空,该插件将适用于所有消费者;config.second:每秒请求限制(int),半可选参数(限制必须存在一项),没有默认值;config.minute:每分钟请求限制(int),半可选参数(限制必须存在一项),没有默认值;config.hour:每小时请求限制(int),半可选参数(限制必须存在一项),没有默认值;config.day:每天请求限制(int),半可选参数(限制必须存在一项),没有默认值;config.month:每月请求限制(int),半可选参数(限制必须存在一项),没有默认值;config.year:每年请求限制(int),半可选参数(限制必须存在一项),没有默认值;config.limit_by:可以使consumer、credential或ip,默认是消费者,如果consumer或credential没有设置时,根据ip来限制,可选参数;# 小时天和年的太久了就没测试config.hide_client_headers:是否隐藏头信息,可选参数,默认False;
添加API
function add_api($data=[]){ if (empty($data)){ $data = [ 'name' => 'ip_api', 'upstream_url' => 'http://ip.taobao.com/service/getIpInfo.php?ip=14.215.177.39', 'methods' => 'GET', 'uris' => '/ip/query' ]; } $curl = curl_init('http://localhost:8001/apis/'); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "POST"); curl_setopt($curl, CURLOPT_POSTFIELDS, $data); $output = curl_exec($curl); curl_close($curl); return $output;}print_r(add_api());exit;
返回值
{ "created_at":1513673389000, "strip_uri":true, "id":"bbe7aaae-ea06-43ad-a69c-43b0889faf26", "name":"ip_api", "methods":[ "GET" ], "http_if_terminated":false, "preserve_host":false, "upstream_url":"http://ip.taobao.com/service/getIpInfo.php?ip=14.215.177.39", "uris":[ "/ip/query" ], "upstream_send_timeout":60000, "upstream_connect_timeout":60000, "upstream_read_timeout":60000, "retries":5, "https_only":false}
关联插件
function rate_limiting($api_name = '', $data = []){ if(empty($data)){ $data = [ 'name' => 'rate-limiting', 'config.minute' => 5, ]; } $curl = curl_init(sprintf('http://localhost:8001/apis/%s/plugins', $api_name)); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "POST"); curl_setopt($curl, CURLOPT_POSTFIELDS, $data); $output = curl_exec($curl); curl_close($curl); return $output;}print_r(rate_limiting('ip_api'));exit;
返回值
{ "created_at":1513673424000, "config":{ "hide_client_headers":false, "minute":5, "policy":"cluster", "redis_database":0, "redis_timeout":2000, "redis_port":6379, "limit_by":"consumer", "fault_tolerant":true }, "id":"85d76dae-b50e-4e25-9f6b-1032a7e92a6f", "name":"rate-limiting", "api_id":"bbe7aaae-ea06-43ad-a69c-43b0889faf26", "enabled":true}
通过http://localhost:8001端口来看看这个API的信息
// http://localhost:8001/apis/ip_api{ "created_at":1513673389000, "strip_uri":true, "id":"bbe7aaae-ea06-43ad-a69c-43b0889faf26", "name":"ip_api", "methods":[ "GET" ], "http_if_terminated":false, "https_only":false, "upstream_url":"http://ip.taobao.com/service/getIpInfo.php?ip=14.215.177.39", "uris":[ "/ip/query" ], "preserve_host":false, "upstream_connect_timeout":60000, "upstream_read_timeout":60000, "upstream_send_timeout":60000, "retries":5}// http://localhost:8001/apis/ip_api/plugins{ "total":1, "data":[ { "created_at":1513673424000, "config":{ "hide_client_headers":false, "minute":5, "policy":"cluster", "redis_database":0, "redis_timeout":2000, "redis_port":6379, "limit_by":"consumer", "fault_tolerant":true }, "id":"85d76dae-b50e-4e25-9f6b-1032a7e92a6f", "enabled":true, "api_id":"bbe7aaae-ea06-43ad-a69c-43b0889faf26", "name":"rate-limiting" } ]}
添加限制组合
function add_limiting($api_name = '', $plugin_id = '', $data = []){ if(empty($data)){ $data = [ 'name' => 'rate-limiting', 'config.second' => 1, ]; } $curl = curl_init("http://localhost:8001/apis/{$api_name}/plugins/{$plugin_id}"); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "PATCH"); curl_setopt($curl, CURLOPT_POSTFIELDS, $data); $output = curl_exec($curl); curl_close($curl); return $output;}print_r(add_limiting('ip_api', '85d76dae-b50e-4e25-9f6b-1032a7e92a6f'));exit;
返回值
{ "created_at":1513673424000, "config":{ "minute":5, "policy":"cluster", "redis_timeout":2000, "hide_client_headers":false, "second":1, "limit_by":"consumer", "redis_port":6379, "redis_database":0, "fault_tolerant":true }, "id":"85d76dae-b50e-4e25-9f6b-1032a7e92a6f", "name":"rate-limiting", "api_id":"bbe7aaae-ea06-43ad-a69c-43b0889faf26", "enabled":true}
测试
头信息
curl -I -X GET http://localhost:8000/ip/queryHTTP/1.1 200 OKContent-Type: text/html; charset=UTF-8Transfer-Encoding: chunkedConnection: keep-aliveX-RateLimit-Limit-minute: 5X-RateLimit-Remaining-minute: 4Server: TengineDate: Tue, 19 Dec 2017 08:57:18 GMTVary: Accept-EncodingX-Powered-By: PHP/5.3.6X-Kong-Upstream-Latency: 59X-Kong-Proxy-Latency: 23Via: kong/0.11.0
访问测试
for ($i = 0; $i < 10; $i++){ $curl = curl_init('http://localhost:8000/ip/query'); curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "GET"); $output = curl_exec($curl); curl_close($curl); print_r($output);}exit();
{ "code":1, "data":"no ip param."}{ "message":"API rate limit exceeded"}
阅读全文
0 0
- kong插件之Rate Limiting
- 【kong系列九】之限流rate-limiting插件
- rate-limiting
- rate limiting
- Open vswitch 之Qos rate-limiting 原理
- Openvswitch之Qos rate-limiting原理
- kong插件之httplog
- Rate Limiting速率限制
- kong插件之Request Transformer
- 【kong系列四】之插件篇
- 【kong系列七】之ACL策略插件
- kong api gateway 插件之acl
- Change Log Rate Limiting In Linux
- 【kong系列五】之 基本认证Basic Authentication插件
- 【kong系列六】之关键字认证key_auth插件
- 【kong系列八】之HMAC认证hmac-auth插件
- 架构必备:Rate limiting 的作用和常见方式
- 架构必备:Rate limiting 的作用和常见方式
- TCP三次握手wireshark抓包分析
- 数据结构-抽象数据类型
- php技能树
- Linux系统下强制踢掉登录用户
- Wget用法、参数解释的比较好的一个文章
- kong插件之Rate Limiting
- 【sql server 2008】从零开始的数据库复习之路(一)
- 李宏毅老师机器学习作业hw0
- tomcat 7/8 启动非常慢的解决方法
- 在maven下搭建ssm项目(转载学习)
- Sql Server 触发器
- 设计模式学习篇(二)---Abstract Factory
- VGG
- JavaScript引擎工作原理的学习途径