如何用PHP设置Beanstalkd
最近我一直在研究使用Beanstalkd和
PHP.我已经学到了很多关于服务器上的设置等问题.
这是我如何看待它: >我在Ubuntu服务器上安装Beanstalkd和任何依赖项(如libevent).然后我启动Beanstalkd守护进程(应该基本上始终运行). #!/bin/sh php worker.php 4)工作脚本将具有这样的执行排队的任务: while(1) { $job = $this->pheanstalk->watch('test')->ignore('default')->reserve(); $job_encoded = json_decode($job->getData(),false); $done_jobs[] = $job_encoded; $this->log('job:'.print_r($job_encoded,1)); $this->pheanstalk->delete($job); } 现在这里是基于上述设置的问题(如果我错了就更正我): 说我有将RSS feed导入到数据库中的任务.如果10位用户一次就这样做,他们都将在“测试”管中排队.然而,他们只能一次执行一个.有10个不同的管全部同时执行会更好吗? 谢谢!
>如果工作人员不要花太多时间来取食饲料,那就没关系了.如果需要,您可以一次运行多个工作人员.我有一个系统(目前使用的是Amazon SQS,但之前我已经和BeanstalkD相似),最多可以有200名(或更多)员工从队列中抽出.
>单个工作脚本(同一脚本运行多次)应该很好 – 脚本可以同时观看多个管,第一个可以保留.您还可以使用job-stat命令来查看特定的$作业来自哪个管理器(或哪个管道)),或者如果需要从其他类型中分配每个类型,则将某些元信息放入消息中. >运行一个工作人员的一个很好的例子是 described here.我还添加了 supervisord(也是一个 useful post开始),以便轻松启动并持续运行每台机器的一些工作人员(我运行shell脚本,如 first link).我会限制它循环的次数,并且将一个数字放入reserve()以使其等待几秒钟或更长时间,使下一个可用的工作不会在紧密循环中失去控制不要停顿 – 即使没有任何事情. 附录: > shell脚本将根据需要运行多次. (链接显示如何根据需要重新运行exec $@).每当PHP脚本退出时,它都会重新运行PHP.>显然有一个Djanjo应用程序显示一些统计信息,但它是微不足道的连接到守护进程,获取一个管子列表,然后获取每个管的统计数据 – 或者只是计数. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- php – Java / 1.4.1_04用户代理与一些jQuery / Javascript
- php – 使用jquery和ajax更新选项列表
- PHP实现多级分类生成树的方法示例
- java将JSON字符串转换为实体类对象,基于net.sf.json实现
- php中的$bar = boolval($foo)和$bar =(bool)$foo有什么区别
- Joomla语言翻译类Jtext用法分析
- php – 用于更新MySQL的JavaScript?
- PHP7扩展开发之基于函数方式使用lib库的方法详解
- 在PHP中,使用DomDocument getElementByID不起作用?我究竟做
- 详谈symfony window下的安装 安装时候出现的问题以及解决方