gpt4 book ai didi

queue - 排队系统 - 启动多个 worker 的好方法是什么?

转载 作者:行者123 更新时间:2023-12-04 04:28:01 24 4
gpt4 key购买 nike

  • 您如何为面向队列的系统设置一个或多个工作脚本?
  • 您如何根据需要安排启动 - 并在必要时重新启动 - 工作脚本? (我正在考虑诸如 init.d/、基于 Ruby 的“神”、DJB 的 Daemontools 等工具)

  • 我正在开发一个异步队列/工作系统,在这种情况下使用 PHP & BeanstalkdD (尽管实际的语言和守护进程并不重要)。任务本身并不太难——将带有命令和参数的数组编码为 JSON,以便通过 Beanstalkd 守护程序进行传输,然后在工作脚本中提取它们以根据需要对其进行操作。

    还有许多其他类似的队列/ worker 设置,例如 Starling , Gearman , Amazon's SQS以及其他更多面向“企业”的系统,例如 IBM 的 MQ 和 RabbitMQ。如果你运行 Gearman 或 SQS 之类的东西 - 你如何启动和控制工作池?问题在于最初的 worker 启动,然后能够添加额外的额外 worker ,随意关闭它们(尽管我可以通过队列发送消息以关闭它们 - 只要一些“观察者”不会自动重新启动它们)。这不是 PHP 问题,它是关于直接设置一个或多个进程以在启动时运行的 Unix 进程,或者向池中添加更多工作人员。

    一个 bash script to loop a script 已经到位 - 这会调用 PHP 脚本,然后从队列中收集并运行任务,偶尔退出以便能够自行清理(它也可以在失败时暂停几秒钟,或通过计划的事件)。这很好用,在此基础上构建工作进程一点也不难。

    获得一个好的工作 Controller 系统是关于灵 active 的,在机器启动时自动启动一个或两个,并且能够在队列繁忙时从命令行添加更多,在不再需要时关闭额外的。

    最佳答案

    我一直在帮助一个 friend ,他正在从事一个项目,该项目涉及一个基于 Gearman 的队列,该队列将向多个服务器池上的各种 PHP 和 C 守护程序分派(dispatch)各种异步作业。

    由于/etc/init.d/中的简单 shell 脚本和以下命令,worker 被设计为像经典的 unix/linux 守护进程一样运行:
    invoke-rc.d myWorker start|stop|restart|reload
    这种机制简单有效。由于它依赖于标准的 linux 功能,即使对您的应用程序了解有限的人也可以启动或停止一个守护程序,如果他们知道它是如何被称为系统级的(在上面的示例中也称为“myWorker”)。

    这种机制的另一个优点是它也使您的工作人员池管理变得容易。您的机器上可能有 10 个守护进程(myWorker1、myWorker2、...),并有一个“工作管理器”根据队列长度启动或停止它们。由于这些命令可以通过 ssh 运行,因此您可以轻松管理多个服务器。

    这个解决方案可能听起来很便宜,但是如果你使用编码良好的守护进程和可靠的管理脚本来构建它,我不明白为什么对于任何平均(如“非关键”)项目来说,它的效率会低于大笔解决方案.

    关于queue - 排队系统 - 启动多个 worker 的好方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/526487/

    24 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com