今天看文档的时候看到 Laravel的 节流限速 (throttling) 。网络上搜索,又看到了Dingo 的节流限速的文档。因此查看Laravel 与Dingo的源码,对比两者之间的相同点与不同点。
两者都是通过中间件处理请求限流
处理方式都是记录缓存key,设置过期时间,在没过期的时候自增,直到超出限制,或key过期
Laravel 限流中间件 Illuminate\Routing\Middleware\ThrottleRequests
Dingo 限流中间件Dingo\Api\Http\Middleware\RateLimit
从上面两个中间件的代码可以看出,Laravel只有再没有超过限制的情况下才会对缓存进行+1操作,而Dingo是先操作再进行判断
Dingo 限制key以请求路径hash为前缀,默认以用户ip作为key。因此可以实现对用户每个url的限制,限制粒度更细
Dingo\Api\Http\RateLimit\Handler
代码如下:
Laravel 中使用用户信息或域名+ip作为限制key,限制粒度只在用户级别
Illuminate\Routing\Middleware\ThrottleRequests
代码如下:
Dingo支持修改限制key,Laravel默认没有支持修改方法
Dingo支持添加多个限制规则,逻辑上使用限制数最小的进行判断。
假设有两个限制器,且都符合限制条件。一个限制1分钟10次,另一个限制2分钟15次,会使用1分钟1次的进行限制判断。
Dingo 返回了过期限制到期时间,Laravel默认不返回限制到期时间
Dingo\Api\Http\RateLimit\Handler
获取限制最少的限制器代码如下:
Dingo\Api\Http\RateLimit\Handler
获取设置的返回头信息代码如下:
Illuminate\Routing\Middleware\ThrottleRequests
获取设置的返回头信息代码如下:
两者实现原理相同,只是在细节上Dingo的功能更加强大。Dingo 限制粒度更细,限制规则上,可扩展性,灵活性都比Laravel强。
两者都是通过中间件处理请求限流。处理方式都是记录缓存key,设置过期时间,在没过期的时候自增,直到超出限制,或key过期。
Laravel只有再没有超过限制的情况下才会对缓存进行+1操作,而Dingo是先操作再进行判断;Dingo 限制key以请求路径hash为前缀,默认以用户ip作为key,限制粒度更细。Dingo支持修改限制key,Laravel默认没有支持修改方法;Dingo支持添加多个限制规则。