Beanstalkd,一个高性能、轻量级的分布式内存队列系统
安装参考GitHub:https://github.com/kr/beanstalkd
启动Beanstalkd : beanstalkd -l 127.0.0.1 -p 11300
通过composer安装 composer require pda/pheanstalk
require 'vendor/autoload.php';
use Pheanstalk\Pheanstalk;
$pheanstalk = new Pheanstalk('127.0.0.1','11300');
通过 new Pheanstalk(host, port) 可以得到Pheanstalk的实例来操作Beanstalkd
$stats = $pheanstalk->stats();
返回:
Pheanstalk\Response\ArrayResponse Object
(
[_name:Pheanstalk\Response\ArrayResponse:private] => OK
[storage:ArrayObject:private] => Array
(
[current-jobs-urgent] => 0 //当前存在优先级的任务数
[current-jobs-ready] => 0 //当前准备就绪的任务数
[current-jobs-reserved] => 0 //当前处于阻塞的任务数
[current-jobs-delayed] => 0 //当前处于延迟状态的任务数
[current-jobs-buried] => 0 //当前预留的任务数
[cmd-put] => 0 //cmd命令为累计运行次数
[cmd-peek] => 0
[cmd-peek-ready] => 0
[cmd-peek-delayed] => 0
[cmd-peek-buried] => 0
[cmd-reserve] => 0
[cmd-reserve-with-timeout] => 0
[cmd-delete] => 0
[cmd-release] => 0
[cmd-use] => 0
[cmd-watch] => 0
[cmd-ignore] => 0
[cmd-bury] => 0
[cmd-kick] => 0
[cmd-touch] => 0
[cmd-stats] => 1
[cmd-stats-job] => 0
[cmd-stats-tube] => 0
[cmd-list-tubes] => 3
[cmd-list-tube-used] => 0
[cmd-list-tubes-watched] => 0
[cmd-pause-tube] => 0
[job-timeouts] => 0 //超时的任务
[total-jobs] => 0 //任务总数
[max-job-size] => 65535 //任务字符串大小
[current-tubes] => 1 //当前的管道数
[current-connections] => 1 //当前打开的连接数
[current-producers] => 0 //当前生产者数量
[current-workers] => 0 //当前消费者数量
[current-waiting] => 0 //发出reserved指令,但没有响应的数量
[total-connections] => 4 //累计链接数量
[pid] => 530 //Beanstalkd进程id
[version] => 1.10 //版本
[rusage-utime] => 0.003545 //进程执行用户代码的时间
[rusage-stime] => 0.007473 //进程执行内核代码的时间
[uptime] => 105855 //从启动到现在运行时间(秒)
[binlog-oldest-index] => 0
[binlog-current-index] => 0
[binlog-records-migrated] => 0
[binlog-records-written] => 0
[binlog-max-size] => 10485760
[id] => 4199e3eca8bfdea8
[hostname] => lmmlwendeMacBook-Air.local
)
)
$stats = $pheanstalk->statsTube('default');
返回:
Pheanstalk\Response\ArrayResponse Object
(
[_name:Pheanstalk\Response\ArrayResponse:private] => OK
[storage:ArrayObject:private] => Array
(
[name] => default //当前管道名
[current-jobs-urgent] => 0 //当前管道存在优先级的任务数
[current-jobs-ready] => 0 //当前管道准备就绪的任务书
[current-jobs-reserved] => 0 //当前管道处于阻塞的任务数
[current-jobs-delayed] => 0 //当前管道处于延迟状态的任务数
[current-jobs-buried] => 0 //当前管道预留的任务数
[total-jobs] => 0 //当前管道总任务数
[current-using] => 1 //当前管道生产者数量
[current-watching] => 1 //当前管道消费者数量
[current-waiting] => 0 //发出reserved指令,但没有响应的数量
[cmd-delete] => 0
[cmd-pause-tube] => 0
[pause] => 0
[pause-time-left] => 0
)
)
$job = $pheanstalk->watch('default')->reserve();
$job_stats = $pheanstalk->statsJob($job);
返回:
Pheanstalk\Response\ArrayResponse Object
(
[_name:Pheanstalk\Response\ArrayResponse:private] => OK
[storage:ArrayObject:private] => Array
(
[id] => 1 //任务job ID
[tube] => test //所处管道
[state] => reserved //当前状态
[pri] => 1024 //任务优先级(默认1024)
[age] => 469 //任务存活时间(秒)
[delay] => 0 //任务延迟时间(秒)
[ttr] => 60 //任务执行时间
[time-left] => 59 //任务在reserve状态维持的秒数
[file] => 0 // binlog-4 默认-0
[reserves] => 2 //总共reserve次数
[timeouts] => 0 //任务超时次数
[releases] => 0 //重设任务次数
[buries] => 0 //预留次数
[kicks] => 0 //释放预留任务次数
)
)
$job = $pheanstalk->peek(1);
$job_stats = $pheanstalk->statsJob($job);
$tube = $pheanstalk->useTube('default');
$tube = $pheanstalk->useTube('default');
$put = $tube->put(
'hello, beanstalk', // 任务内容
1024, // 任务的优先级
10, // 不等待直接放到ready队列中
60 // 处理任务的时间
);
或者:
$pheanstalk->putInTube('default', 'test1', 1024, 10, 60);
$tube = $pheanstalk->watch('user');
$tube = $pheanstalk->watch('user')->ignore('default');
$job = $pheanstalk->watch('user')->reserve(4); //堵塞时间为4秒
$pheanstalk->listTubesWatched();
$pheanstalk->reserveFromTube('default')
$job = $pheanstalk->watch('default')->reserve();
$pheanstalk->delete($job);
$job = $pheanstalk->watch('default')->reserve();
$pheanstalk->release($job);
$job = $pheanstalk->watch('default')->reserve();
$pheanstalk->touch($job);
$job = $pheanstalk->watch('default')->reserve();
$pheanstalk->bury($job);
$job = $pheanstalk->peekBuried('default');
$pheanstalk->kickJob($job);
$pheanstalk->userTube('default')->kick(999); //将id小于999的预留任务全部释放
$job = $pheanstalk->peekReady('default');
$job = $pheanstalk->peekDelayed('default');
$pheanstalk->pauseTube('default', 100); //设置100秒延迟
$pheanstalk->resumeTube('default');
参考文章:
PHP 操作 Beanstalkd 方法及参数注释
PHP使用Beanstalkd消息队列