PHPackages                             kickpeach/queue - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Queues &amp; Workers](/categories/queues)
4. /
5. kickpeach/queue

ActiveLibrary[Queues &amp; Workers](/categories/queues)

kickpeach/queue
===============

基于beanstalkd实现的任务队列，方便去分发任务和解决任务

1261PHP

Since Feb 6Pushed 7y ago1 watchersCompare

[ Source](https://github.com/KickPeach/queue)[ Packagist](https://packagist.org/packages/kickpeach/queue)[ RSS](/packages/kickpeach-queue/feed)WikiDiscussions master Synced 3d ago

READMEChangelogDependenciesVersions (1)Used By (1)

queue
=====

[](#queue)

基于beanstalkd实现的任务队列，方便去分发任务和解决任务,此库可适用以下场景：

- 用作延时队列：比如可以用于如果用户30分钟内不操作，任务关闭。
- 用作定时任务：比如可以用于专门的后台任务。
- 用作异步操作：这是所有消息队列都最常用的，先将任务仍进去，顺序执行。
- 用作循环队列：用release命令可以循环执行任务，比如可以做负载均衡任务分发。
- 用作兜底机制：比如一个请求有失败的概率，可以用Beanstalk不断重试，设定超时时间，时间内尝试到成功为止

关于Beanstalkd
------------

[](#关于beanstalkd)

Beanstalkd 是一个轻量级的内存型队列，利用了和 Memcache 类似的协议。依赖 libevent 单线程事件分发机制, 可以部署多个实例，但是高并发支持还是不太友好；

几个重要的概念
-------

[](#几个重要的概念)

- job：一个需要异步处理的任务，是 Beanstalkd 中的基本单元，需要放在一个 tube 中。
- tube：一个有名的任务队列，用来存储统一类型的 job，是 producer 和 consumer 操作的对象。
- producer：Job 的生产者，通过 put 命令来将一个 job 放到一个 tube 中。
- consumer：Job的消费者，通过 reserve/release/bury/delete 命令来获取 job 或改变 job 的状态。

### Job的生命周期

[](#job的生命周期)

任务在队里之中被称作 Job. 一个 Job 在 Beanstalkd 中有以下的生命周期：

- put 将一个任务放置进 tube 中
- deayed 这个任务现在再等待中，需要若干秒才能准备完毕【延迟队列】
- ready 这个任务已经准备好了，可以消费了。所有的消费都是要从取 ready 状态的 job
- reserved 这个任务已经被消费者消费
- release 这个 job 执行失败了，把它放进 ready 状态队列中。让其他队列执行
- bury 这个 job 执行失败了，但不希望其他队列执行，先把它埋起来

```

     put with delay               release with delay
      ----------------> [DELAYED]  [READY] ---------> [RESERVED] --------> *poof*
                           ^  ^                |  |
                           |   \  release      |  |
                           |    `-------------'   |
                           |                      |
                           | kick                 |
                           |                      |
                           |       bury           |
                        [BURIED]
