gearman 与pcntl配合使用
2016-04-26 14:51
218 查看
Gearman是一个分布式的任务分发处理系统。
但是它无法完成启动多线程的任务,所以在一台机器上只用Gearman无法实现并行,
即使new了很多GearmanWorker也是只有一个worker工作。
应该使用pcntl_fork()出一些子进程,在每个子进程中new一个GearmanWorker,
这样就可以实现并行处理了。
合理分配好任务数量和每个任务的工作量有助于提升处理速度。
还有一点很重要,GearmanClient::doBackgroud GearmanClient::addTaskBackgroud的区别,
可以参考 http://stackoverflow.com/questions/12689274/whats-the-difference-between-a-task-and-do
但是它无法完成启动多线程的任务,所以在一台机器上只用Gearman无法实现并行,
即使new了很多GearmanWorker也是只有一个worker工作。
应该使用pcntl_fork()出一些子进程,在每个子进程中new一个GearmanWorker,
这样就可以实现并行处理了。
for ($i=0; $i < 10; $i++) { if (($pid = pcntl_fork()) == 0) { //子进程 $gmworker = new GearmanWorker(); $gmworker->addServer(); $gmworker->addFunction("sendmail", "sendmail_fn"); while($gmworker->work()); } else { //主进程 } } while (1);
合理分配好任务数量和每个任务的工作量有助于提升处理速度。
还有一点很重要,GearmanClient::doBackgroud GearmanClient::addTaskBackgroud的区别,
可以参考 http://stackoverflow.com/questions/12689274/whats-the-difference-between-a-task-and-do
相关文章推荐
- Python3写爬虫(四)多线程实现数据爬取
- C#实现多线程的同步方法实例分析
- 浅谈chuck-lua中的多线程
- C#简单多线程同步和优先权用法实例
- C#多线程学习之(四)使用线程池进行多线程的自动管理
- C#多线程编程中的锁系统(三)
- 解析C#多线程编程中异步多线程的实现及线程池的使用
- C#多线程学习之(六)互斥对象用法实例
- 基于一个应用程序多线程误用的分析详解
- C#多线程学习之(三)生产者和消费者用法分析
- C#多线程学习之(一)多线程的相关概念分析
- C#多线程之Thread中Thread.IsAlive属性用法分析
- 分享我在工作中遇到的多线程下导致RCW无法释放的问题
- C#多线程编程之使用ReaderWriterLock类实现多用户读与单用户写同步的方法
- C#控制台下测试多线程的方法
- 21天学习android开发教程之SurfaceView与多线程的混搭
- Ruby 多线程的潜力和弱点分析
- C#中WPF使用多线程调用窗体组件的方法
- C#如何对多线程、多任务管理(demo)
- C#实现多线程的Web代理服务器实例