自动启动多个upstart实例

mkg*_*der 28 upstart instance worker gearman

我们使用PHP gearman worker并行运行各种任务.一切都运行得很好,我有愚蠢的小shell脚本,当我想要它们时将它们旋转起来.作为一名程序员(因此也是懒惰的),我想看看我是否可以通过一个新手脚本来解决这些问题.

我想出了如何使用实例节,所以我可以使用实例编号启动它们:

description "Async insert workers"
author      "Mike Grunder"

env SCRIPT_PATH="/path/to/my/script"

instance $N

script
    php $SCRIPT_PATH/worker.php
end script
Run Code Online (Sandbox Code Playgroud)

这很好用,就像这样开始它们:

sudo start async-worker N=1
sudo start async-worker N=2
Run Code Online (Sandbox Code Playgroud)

我想要使​​用这些工作者的方法是调整其中的一些(可能每个核心一个等),我想在启动时这样做.要清楚,我不需要upstart脚本来检测核心数量.我很高兴只说"做8个实例",但这就是我想要多次运行的原因.有没有办法让我在upstart脚本中使用"start on"子句自动执行此操作?

例如,启动实例1,2,3,4?然后让它们在关机时正常退出?

我想我可以将它挂钩到init.d脚本中,但我想知道upstart是否可以处理这样的事情,或者是否有人已经弄清楚了这个问题.

干杯啦!

cwi*_*ick 40

您需要的是一个在启动时运行的引导任务,并迭代所有工作者作业,从每个作业开始.

#/etc/init/async-workers-all.conf

start on runlevel [2345]

task

env NUM_WORKERS=8

script
  for i in `seq 1 $NUM_WORKERS`
  do
    start async-worker N=$i
  done
end script
Run Code Online (Sandbox Code Playgroud)

关键是要将此作为一项任务,告诉upstart让任务在为其发出任何事件之前运行完成.请参阅http://upstart.ubuntu.com/cookbook/#taskhttp://upstart.ubuntu.com/cookbook/#instance

  • 您还应该检查http://stackoverflow.com/questions/12084025/restarting-upstart-instance-prcesses,它不仅允许启动多个实例,还允许它们停止. (11认同)