PHP-php如可开启多个进程处理任务
脚本daily.php
从数据库里获取一个任务列表,并且传递给run.php处理,处理时间大约在1分钟
脚本run.php
获取参数进行任务处理。
问题:如何让这个列表里的多个任务同时执行(不考虑CPU)
尝试使用proc_open(),
并且在run.php里写sleep(1000);实际效果为如果sleep不结束后面代码是不会执行的,
所以我想问,有什么方法能让这个需求实现呢?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
我记得以前做个一个类似的问题,场景是这样的:用户分享一个文件给TA的朋友们(也许很多的那种),需要给所有分享者发送一封邮件,当时我的处理办法是把必要的信息写入数据库,然后使用fsocket的办法模拟一个新的请求给服务器然后开启了一新的进程。和imeio的办法类似。
我最近也在研究PHP多进程。有点经验可以分享。
您说的那种proc_open()方式开启一个进程,我记得好像是在子进程返回之前父进程会阻塞。所以实际上仍然是串行执行的。
在LINUX下有一个PCNTL扩展可以实现PHP的多进程。您可以去研究相关代码。我这里收藏了几个网址,这几篇文章写的还是非常不错的。推荐给您。
http://www.cnblogs.com/niniwzw/archive/2009/09/27/1575002.html
http://www.laruence.com/2009/06/11/930.html
另外风大大写了一个PHP多进程SORCKET框架,如果有帮助您也可以研究下。框架叫MPASS,在code.google.com里搜索就可以了。
希望以上信息能够对您有所帮助。
可以通过PHP的cURL借用apache的多进程。
$urls = array('url_1','url_2');
$ch = curl_init();
foreach($urls as $url){
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_TIMEOUT, 1);
curl_exec($ch);
}
curl_close($ch);