This article mainly introduces the methods and parameter comments about operating Beanstalkd in PHP. It has certain reference value. Now I share it with everyone. Friends in need can refer to it
Beanstalk is a high-performance, lightweight distributed memory queue system. It was originally designed to reduce the page access of high-volume web application systems by asynchronously executing time-consuming tasks in the background. Delay, supported the Facebook Causes application with 9.5 million users.
Later open sourced, PostRank is now deployed and used on a large scale, processing millions of tasks every day. Beanstalkd is a typical Memcached-like design. The protocol and usage are the same, so users who have used memcached will feel that Beanstalkd looks familiar.
job typical life cycle
put reserve delete -----> [READY] ---------> [RESERVED] --------> *poof*
job possible state migration
put with delay release with delay ----------------> [DELAYED] <------------. | | kick | (time passes) | | | put v reserve | delete -----------------> [READY] ---------> [RESERVED] --------> *poof* ^ ^ | | | \ release | | | `-------------' | | | | kick | | | | bury | [BURIED] <---------------' | | delete `--------> *poof*
Skip the installation, if necessary please refer to click reference
Note: Composer needs to be installed, tutorial link Composer installation method
The PHP
third-party library used to operate Beanstalkd
, the installation is skipped, if necessary, please refer to the reference
<?php require __DIR__ . '/vendor/autoload.php'; use Pheanstalk\Pheanstalk; /** * 实例化beanstalk * 参数依次为:ip地址 端口号默认11300 连接超时时间 是否长连接 */ $pheanstalk = new Pheanstalk('127.0.0.1', 11300, 3, false); ?>
Beanstalkd status
$stats = $pheanstalk->stats();
Return:
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 ) )
Current pipeline list
$listTubes = $pheanstalk->listTubes();
View pipeline details
$stats = $pheanstalk->statsTube();
Return:
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 ) )
View task details
$job = $pheanstalk->watch('default')->reserve(); $job_stats = $pheanstalk->statsJob($job);
Return:
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 //释放预留任务次数 ) )
View task details (by ID)
$job = $pheanstalk->peek(1); $job_stats = $pheanstalk->statsJob($job);
Specify the pipeline to be used
$tube = $pheanstalk->useTube('default');
Insert data into the pipe
$tube = $pheanstalk->useTube('default'); $put = $tube->put( 'hello, beanstalk', // 任务内容 1024, // 任务的优先级 10, // 不等待直接放到ready队列中 60 // 处理任务的时间 );
Or:
$pheanstalk->putInTube('default', 'test1', 1024, 10, 60);
Listening pipe
$tube = $pheanstalk->watch('user');
Remove pipes that do not need to be monitored
$tube = $pheanstalk->watch('user')->ignore('default');
Listen to the pipe in a blocked manner
$job = $pheanstalk->watch('user')->reserve(4); //堵塞时间为4秒
List all monitored pipes
$pheanstalk->listTubesWatched();
watch reserve method
$pheanstalk->reserveFromTube('default')
Delete the current task
$job = $pheanstalk->watch('default')->reserve(); $pheanstalk->delete($job);
Reset the current task Put it into the pipe
$job = $pheanstalk->watch('default')->reserve(); $pheanstalk->release($job);
to extend the life of the task (when the time to process the task is less than the current task execution time)
$job = $pheanstalk->watch('default')->reserve(); $pheanstalk->touch($job); //TODO
Reserve the task
$job = $pheanstalk->watch('default')->reserve(); $pheanstalk->bury($job);
Release the reserved task (change to reday status)
$job = $pheanstalk->peekBuried('default'); $pheanstalk->kickJob($job);
Release reserved tasks in batches
$pheanstalk->userTube('default')->kick(999); //将id小于999的预留任务全部释放
Read the currently ready tasks (ready)
$job = $pheanstalk->peekReady('default');
Read the task currently in delayed state (delayed)
$job = $pheanstalk->peekDelayed('default');
Set delay for pipeline
$pheanstalk->pauseTube('default', 100); //设置100秒延迟
Cancel the delay on the pipeline
$pheanstalk->resumeTube('default');
The above is the entire content of this article, I hope it will be useful for everyone’s learning Help, please pay attention to the PHP Chinese website for more related content!
Related recommendations:
The intranet penetration application Spike implemented by PHP has been reconstructed
php calls phantomjs to WeChat Mini program sharing
The above is the detailed content of Methods and parameter comments for operating Beanstalkd in PHP. For more information, please follow other related articles on the PHP Chinese website!