承接 danc0/balin-queue 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

danc0/balin-queue

最新稳定版本:v0.1.4

Composer 安装命令:

composer require danc0/balin-queue

包简介

A simple PHP database based queue

README 文档

README

A simple database queue for PHP.

Supports:

  • MySQL/MariaDB
  • SQLite3

Installation

composer require danc0/balin-queue

Config

$Balin = Balin::load([
	'path' => __DIR__,
	'database' => [
		'driver' => 'sqlite',
		'name' => 'balin_queue.sqlite',
		'dsn' => 'sqlite:' . __DIR__ . '/balin_queue.sqlite'
	]
]);

Driver Options:

  • sqlite
  • mysql

A flag file is created in path to indicate that the queue has been created, make sure the path is writable. This is also where the sqlite database will be created if using sqlite.

Usage

You would first create an instance of Balin somewhere with the config example above. To access the instance of Balin you would use the following code:

$Balin = Balin::queue();

At this point you have a number of public methods you can use.

Push to queue

push(string $task_name, array $payload, int $priority = 99, int $max_attempts = 3, string $scheduled_at = null)

This will push a task to the queue. Use lower numbers for higher priority. The default priority is 99. The default max attempts is 3. The default scheduled at is null. Using scheduled at will delay the task until the time specified.

Getting a job

pop()

This will return the next job in the queue. If there are no jobs in the queue it will return null. This will pull based on priority, scheduled at time, and created time.

popTask(string $task_name)

This will return the next job in the queue for the specified task name. If there are no jobs in the queue it will return null. This will pull based on priority, scheduled at time, and created time, but only for the specified task name.

Update a job

success(int $id)

This will mark the job as successful and remove it from the queue.

failure(int $id, string|null $scheduled_at = null)

This will mark the job as failed and put it back in the queue. If the job has reached the max attempts it will be removed from the queue. If you pass a scheduled at time it will delay the job until that time.

error(int $id, string $error_message)

This will mark the job as having an error and remove it from the queue.

Releasing orphaned jobs

releaseLockedJobs(int $locked_max_time = 3600)

This will release any jobs that have been locked for more than the specified time. The default is 3600 seconds (1 hour).

统计信息

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

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: Unlicense
  • 更新时间: 2024-11-28

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固