文档章节

使用QPM编写PHP 多进程程序

AlexQ
 AlexQ
发布于 2015/03/10 21:36
字数 378
阅读 75
收藏 1

QPM全名是 Quick Process Managment Module for PHP. PHP 是强大的web开发语言,以至于大家常常忘记PHP 可以用来开发健壮的命令行(CLI)程序以至于daemon程序。 而编写daemon程序免不了与各种进程管理打交道。QPM正式为简化进程管理而开发的类库。

QPM 项目地址在:https://github.com/Comos/qpm

以下是用QPM编写多进程程序的小例子。

//定义 mission1:每隔3秒打印一次进程信息, 无限循环。
$mission1 = function() {
    while(true) {
            echo "---mission 1, pid:".posix_getpid()."\n";
            sleep(3);
    }
};

//定义 mission2:打印信息后 3秒后退出。
$mission2 = function() {
            echo "+++mission 2,pid:".posix_getpid()."\n";
            sleep(3);
};

//配置: mission 1 和mission 2 同时在子进程中执行。mission 1 只允许在一个子进程中执行,mission 2 则允许2个子进程并行执行。
$config = [
    ['runnableCallback'=>$mission1],
    ['runnableCallback'=>$mission2, 'quantity'=>2]
];
// 使用multiGroupOneForOne 类型的supervisor 启动任务,意味着同组配置,当一个子进程退出后,会立即重启新的子进程继续执行任务。
qpm\supervisor\Supervisor::multiGroupOneForOne($config)->start();

0.1是QPM 对外发布的第一个stable 版本,在这个版本里,实现了fork的面向对象的写法,极大的简化了fork代码的可读性;同时实现了一系列Supervisor的用法,可以帮助开发者编写健壮的多进程程序。 在未来的版本里,计划逐步开发出信号处理和跨进程通迅的模块。

© 著作权归作者所有

AlexQ
粉丝 5
博文 10
码字总数 3706
作品 0
海淀
私信 提问
QPM-PHP进程管理框架

QPM全名是 Quick Process Management Framework for PHP. PHP 是强大的web开发语言,以至于大家常常忘记PHP 可以用来开发健壮的命令行(CLI)程序以至于daemon程序。 而编写daemon程序免不了...

AlexQ
2015/03/10
397
0
PHP进程管理框架--QPM

QPM全名是 Quick Process Management Framework in PHP. PHP 是强大的 web 开发语言,以至于大家常常忘记 PHP 可以用来开发健壮的命令行(CLI)程序以至于 daemon 程序。 而编写 daemon 程序...

赵青
2015/02/27
1K
0
PHP使用QPM实现多进程并行任务处理程序

考虑用PHP实现以下场景: 有一个抓站的URL列表保存在队列里,后台程序读取这个队列,然后转交给子进程去抓取HTML存放到文件里。 为了提高效率,允许多任务并行执行,但为了避免机器负载过高,...

AlexQ
2015/03/10
2.9K
13
php多进程框架-模拟java多线程接口--simple-fork-php

SimpleFork simple-fork-php 是基于 PCNTL 扩展的进程管理包,接口类似与 Java 的 Thread 和 Runnable 为什么要写 SimpleFork 多进程程序的编写相比较多线程编写更加复杂,需要考虑进程回收、...

呼延平
2015/08/19
434
0
**小草**/taskPHP

当前版本 2.0 历史版本 -->taskPHP1.0 taskPHP taskPHP基于php开发的定时计划任务框架,利用多进程实现任务的分配和运行,多种进程间通信驱动支持,支持多线程模式需要安装pthreads扩展(可选),支...

**小草**
2017/04/06
0
0

没有更多内容

加载失败,请刷新页面

加载更多

【TencentOS tiny】深度源码分析(4)——消息队列

消息队列 在前一篇文章中【TencentOS tiny学习】源码分析(3)——队列 我们描述了TencentOS tiny的队列实现,同时也点出了TencentOS tiny的队列是依赖于消息队列的,那么我们今天来看看消息...

杰杰1号
32分钟前
6
0
Hive

这就是那个 JAVA 类 package cn.itcast.bigdata;import java.util.HashMap;import org.apache.hadoop.hive.ql.exec.UDF;public class PhoneNbrToArea extends UDF{privat......

Garphy
32分钟前
7
0
Springboot开发,第二天

SpringBoot学习,第二天 目录:1、Springboot整合Listener 2、Springboot访问静态资源 3、异常处理 4、热部署 一、SpringBoot整合Listener 两种方式完成组件的注册 1、通过注解扫描完成组件的...

有一个小阿飞
36分钟前
7
0
BeginnersBook Perl 教程

来源:ApacheCN BeginnersBook 翻译项目 译者:飞龙 协议:CC BY-NC-SA 4.0 贡献指南 本项目需要校对,欢迎大家提交 Pull Request。 请您勇敢地去翻译和改进翻译。虽然我们追求卓越,但我们并...

ApacheCN_飞龙
48分钟前
5
0
我的Java秋招面经大合集

阿里面经 阿里中间件研发面经 蚂蚁金服研发面经 岗位是研发工程师,直接找蚂蚁金服的大佬进行内推。 我参与了阿里巴巴中间件部门的提前批面试,一共经历了四次面试,拿到了口头offer。 然后我...

Java技术江湖
53分钟前
9
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部