shipsaas/safe-dispatcher 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

shipsaas/safe-dispatcher

最新稳定版本:1.2.0

Composer 安装命令:

composer require shipsaas/safe-dispatcher

包简介

Ensure your Queue msg is tracked and retryable when failed to dispatch.

README 文档

README

Latest Version Total Downloads codecov Build & Test Build & Test (Laravel 9, 10) Try Install Package (Laravel 9 & 10)

For Laravel, it has the Queues feature, all cool and easy to use, right?

But what if it fails to dispatch a job? Then you have no idea for:

  • What was the data inside the msg?
  • What was the error? Traces?
  • How to resend the Queue msg with minimal effort?

Then it will cost you a lot of time to check the log, sentry issues, create retry command,... Awful, IKR?

Worries no more, SafeDispatcher got your back. Check out how it works below.

Documentation:

How SafeDispatcher works?

How does Laravel SafeDispatcher works?

SafeDispatcher will:

  • Store the failed to dispatch msgs.
  • Retry them on demand.
  • You can even change the connection driver or the name on retry.
    • Would really come in handy when you have a SQSException (size > 256kb), then you can resend using redis/database driver.
  • Ensure that your processing/flow is still working properly (no 500 server error from HTTP or exceptions from queue worker).
    • Super useful & helpful for mission-critical apps.

Requirements

  • Laravel 9+ & 10+
  • PHP 8.1 & 8.2

Installation

composer require shipsaas/safe-dispatcher

Usage

Dependency Injection

use SaasSafeDispatcher\Bus\SafeDispatcher;

class RegisterService
{
    public function __construct(public SafeDispatcher $dispatcher) {}

    public function register(): void
    {
        $user = User::create();
        
        $job = new SendEmailToRegisteredUser($user);
        $this->dispatcher->dispatch($job);
    }
}

Use Trait for your Job

use SaasSafeDispatcher\Traits\SafeDispatchable;

class SendEmailToRegisteredUser implements ShouldQueue
{
    use SafeDispatchable;
}

SendEmailToRegisteredUser::safeDispatch($user);

Quick Helper Functions

safeDispatch(new SendEmailToRegisteredUser($user));

safeDispatch(() => echo('Hello'));

safeDispatchSync(new SendEmailToRegisteredUser($user));

Cover Queue Facade (v1.2.0+)

use SaasSafeDispatcher\Services\SafeQueue;

SafeQueue::prepareFor(new Job())
    ->push('high'); # Push to "high" queue name

Learn more Cover Queue Facade

Notes

  • SafeDispatcher hasn't supported with batching & chaining.
    • Alternatively, you can do normal ::safeDispatch and after finish your job, dispatch another,...
  • SafeDispatcher considers the sync Queue as a Queue Msg.
    • Therefore, if the handling fails, Queue Msg will be stored too.
  • SafeDispatcher ships some helpful APIs too, check it out: APIs

Tests

SafeDispatcher is not only have normal Unit Testing but also Integration Test (interacting with MySQL for DB and Redis for Queue).

We're planning to add other queue drivers too (database or SQS).

To run the test, hit this:

composer test

Contribute to the project

  • All changes must follow PSR-1 / PSR-12 coding conventions.
  • Unit testing is a must, cover things as much as you can.

Maintainers & Contributors

  • Seth Phat

Join me 😉

This library is useful?

Thank you, please give it a ⭐️⭐️⭐️ to support the project.

Don't forget to share with your friends & colleagues 🚀

License

Copyright © by ShipSaaS 2023 - Under MIT License.

统计信息

  • 总下载量: 17
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 30
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 30
  • Watchers: 2
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-02-14

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固