首页
/ 限制速率的 Laravel 工作中间件

限制速率的 Laravel 工作中间件

2024-05-21 03:25:51作者:劳婵绚Shirley

最新版本 测试运行 总下载量

laravel-rate-limited-job-middleware 是一个针对 Laravel 应用的工作(Job)中间件,它可以实现对任务执行速率的有效控制。

支持我们

查看我们的广告以支持我们的开源项目。您还可以通过购买我们的付费产品来直接支持我们。在使用我们的包时,请考虑发送一张来自您的家乡的明信片到我们的地址,您可以在我们的联系页面找到它。所有收到的明信片都会被展示在我们的虚拟明信片墙上

安装

使用 Composer 可以轻松安装这个包:

composer require spatie/laravel-rate-limited-job-middleware

请注意,此包要求您的 Laravel 应用已配置好 Redis。

使用方法

默认情况下,中间件将允许每秒执行最多 5 个任务。超出限制的任务将会在 5 秒后释放。要应用这个中间件,只需在你的 Job 类中添加 Spatie\RateLimitedMiddleware\RateLimited 到中间件数组:

namespace App\Jobs;

use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Spatie\RateLimitedMiddleware\RateLimited;

class TestJob implements ShouldQueue
{
    use Dispatchable, InteractsWithQueue, Queueable;

    public function handle()
    {
        // 执行任务逻辑
    }

    public function middleware()
    {
        return [new RateLimited()];
    }
}

配置尝试次数

由于存在速率限制,工作类的尝试次数可能难以预估。建议使用基于时间的尝试次数,例如:

public function retryUntil() :  \DateTime
{
    return now()->addDay();
}

自定义行为

您可以自定义中间件的所有行为。以下是一个例子,允许在 60 秒内最多执行 30 个任务,并且不被允许的任务将在 90 秒后释放:

// 在你的 job 中

public function middleware()
{
    $rateLimitedMiddleware = (new RateLimited())
        ->allow(30)
        ->everySeconds(60)
        ->releaseAfterSeconds(90);

    return [$rateLimitedMiddleware];
}

实现指数退避策略

远程服务如 API 常有速率限制,或在处理时出现服务器错误。在这种情况下,在再次尝试之前增加延迟是合理的。你可以用 releaseAfterBackoff($this->attempts()) 替换 releaseAfter 方法来使用默认的 5 秒间隔。否则,您可以链式调用 releaseAfter 来调整退避间隔。

功能特性

  • 默认限制为每秒 5 个工作,未被允许的任务将等待 5 秒。
  • 支持自定义每秒允许的最大任务数和时间跨度。
  • 提供了配置释放延时的选项,包括指数退避策略。
  • 可以选择不释放被限制的任务。
  • 允许有条件地应用中间件,如只在特定条件下启用。
  • 能够自定义 Redis 连接和存储键。

如何定制化?

例如,您可以设置 60 秒内最大 30 次尝试,失败则等待 90 秒:

public function middleware()
{
    $rateLimitedMiddleware = (new RateLimited())
        ->allow(30)
        ->everySeconds(60)
        ->releaseAfterSeconds(90);

    return [$rateLimitedMiddleware];
}

测试与贡献

使用 composer test 命令进行测试。详细信息请参考 CONTRIBUTING 文件。

许可证

本项目遵循 MIT 许可协议。详情请见 LICENSE.md 文件。


laravel-rate-limited-job-middleware 是 Laravel 社区的一份强大的礼物,它为您的任务队列提供了精细的速率控制,确保服务的稳定性和效率。其简洁的配置和高度定制性使其成为任何 Laravel 开发者实现任务限速的理想选择。立即加入那些已经在享受其便利的开发者行列吧!

登录后查看全文
热门项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
24
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
271
2.55 K
flutter_flutterflutter_flutter
暂无简介
Dart
559
125
fountainfountain
一个用于服务器应用开发的综合工具库。 - 零配置文件 - 环境变量和命令行参数配置 - 约定优于配置 - 深刻利用仓颉语言特性 - 只需要开发动态链接库,fboot负责加载、初始化并运行。
Cangjie
141
12
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
cangjie_runtimecangjie_runtime
仓颉编程语言运行时与标准库。
Cangjie
127
104
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
357
1.84 K
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.02 K
434
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.03 K
606
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
731
70