【发布时间】:2015-10-06 14:18:00
【问题描述】:
我知道 Laravel 的队列驱动程序,例如 redis 和 beanstalkd,我读到您可以增加 beanstalkd 等的工作人员数量。但是我不确定这些解决方案是否适合我的场景。这就是我需要的;
我通过套接字连接收听 XML 提要,并且数据不断快速传递。永远。我在一秒钟内获得了数十个 XML 文档。
我从这个套接字逐行读取数据,一旦我到达 XML 结束标记,我就会将缓冲区发送到另一个进程进行解析。我过去只是在 base64 中编码 xml,并为每个 xml 运行一个单独的 php 进程。 shell_exec('php parse.php' . $base64XML);
这让我能够非常快速地解析这个永无止境的 xml 数据。一种手动穿线。现在我想在 Laravel 中使用相同的功能,但我想知道是否有更好的方法来做到这一点。我相信 Artisan::call('command') 不会把它推到后台。我当然也可以在 Laravel 中执行 shell_exec,但我想知道我是否可以从 Beanstalkd 或类似的解决方案中受益。
所以真正的问题是:如何为 beanstalkd 或 redis 驱动程序设置队列工作人员的数量?就像我想要同时运行 20 个线程一样。如果可能的话,更多。
一个稍微不那么重要的问题是:多少线程才算太多?如果我有一个非常高端的专用服务器可以很好地处理负载,那么使用这些工具创建 500 个线程/worker 会导致代码级别的任何问题吗?
【问题讨论】:
标签: php multithreading laravel pthreads beanstalkd