xsdys / limit
一个限流组件,支持自然周期和非自然周期
Installs: 56
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/xsdys/limit
Requires
- nesbot/carbon: ^1.38.14|^2.25
- predis/predis: ^1.1.1
This package is auto-updated.
Last update: 2025-12-29 02:59:42 UTC
README
自然周期
就是年月日,这样的周期,每(天/月,日...)的开始时间为周期的开始,结束时间为周期结束
非自然周期
就是多少秒为一个周期,第一个请求为周期开始,周期秒数后为周期结束,当有新的请求进入后为周期开始(没有新的请求进入即不开始新的周期),示例 周期为10秒,第一个请求时间为2014:09:12 00:00:01,那么2014:09:12 00:00:01-2014:09:12 00:00:11为这个周期,但是当00:00:01-2014:09:12 00:00:11之后如果你没有新的请求
简单示例:
$config = [ "host" => "10.0.1.120", "password" => null, "port" => "6379", "database" => 1, ]; $config = config('database.redis.cache'); $id = 1; $limit = new \limit\Limit('a1', $id, 10, 'h', true,$config); dump($limit->used(1)); # 使用成功返回true dump( $limit->check(1));# 预检是否可用,成功返回true # 应该先预检后使用
初始化
$config = [ "host" => "10.0.1.120", "password" => null, "port" => "6379", "database" => 1, ]; $config = config('database.redis.cache'); $id = 1; $limit = new \limit\Limit('user', $id, 10, 'h', true,$config);
六个参数
$name名字,验证器的名字$idID,验证起的ID,与名字一起构成唯一标示,例如:user-1$limit限流数量,单位周期的限流数量$cycle周期,非自然周期为秒数,自然周期为:y# 年m# 月d# 日w# 周h# 小时i# 分钟s# 秒
$natural是否为自然周期,默认为true$config配置项,样式如下,option为Predis的第二个参数
$defalut = [ 'scheme' => 'tcp', 'host' => '127.0.0.1', 'password' => null, 'port' => 6379, 'database' => 0, 'option'=>[ 'prefix'=>'limit' ] ];
开始使用
check(int $value = 0 ):bool,检查是否有这些值可用,传入的是预检的值,> 剩余值则不可用getRemaining(),获取剩余可用值getUsed(),获取已使用值used(int $value=1,$order=null),使用一些值$value是要使用的值$order进行订单判断,未实现