为什么当我将 rake assets:precompile 任务添加到我的 Procfile 时,Foreman 退出?

Why does Foreman exit when I add a rake assets:precompile task to my Procfile?

我在 Rails 上的 Ruby 应用程序使用工头 (https://github.com/ddollar/foreman) 来管理应用程序 运行.[=22= 时需要启动的进程]

我的 Procfile 看起来像这样:

precompile: bundle exec rake assets:precompile
web: bundle exec puma -e $PUMA_ENV
worker: bundle exec rake jobs:work
search: bundle exec rake sunspot:solr:run

运行 $ foreman start 按预期工作,直到我添加第一行(precompile 任务)。

当我 运行 $ foreman start 我的输出如下所示:

$ foreman start -e .env.dev
10:30:20 precompile.1 | started with pid 7309
10:30:20 web.1        | started with pid 7310
10:30:20 worker.1     | started with pid 7311
10:30:20 search.1     | started with pid 7312
10:30:22 web.1        | [7310] Puma starting in cluster mode...
10:30:22 web.1        | [7310] * Version 2.8.2 (ruby 2.1.0-p0), codename: Sir Edmund Percival Hillary
10:30:22 web.1        | [7310] * Min threads: 4, max threads: 16
10:30:22 web.1        | [7310] * Environment: development
10:30:22 web.1        | [7310] * Process workers: 2
10:30:22 web.1        | [7310] * Phased restart available
10:30:22 web.1        | [7310] * Listening on tcp://0.0.0.0:3000
10:30:22 web.1        | [7310] Use Ctrl-C to stop
10:30:23 web.1        | [7313] + Gemfile in context: /Users/username/rails_projects/lcms/Gemfile
10:30:23 web.1        | [7314] + Gemfile in context: /Users/username/rails_projects/lcms/Gemfile
10:30:30 web.1        | [7310] - Worker 1 (pid: 7314) booted, phase: 0
10:30:30 worker.1     | [Worker(host:MacBook-Pro.local pid:7311)] Starting job worker
10:30:30 web.1        | [7310] - Worker 0 (pid: 7313) booted, phase: 0
10:30:32 precompile.1 | exited with code 0
10:30:32 system       | sending SIGTERM to all processes
SIGTERM received
10:30:32 web.1        | [7310] - Gracefully shutting down workers...
10:30:32 worker.1     | [Worker(host:MacBook-Pro.local pid:7311)] Exiting...
10:30:32 search.1     | exited with code 143
10:30:32 web.1        | [7310] - Goodbye!
10:30:32 web.1        | exited with code 0
10:30:33 worker.1     | exited with code 0

我不知道如何获得有关该问题的更多详细信息。我在我的 config/environments/development.rb 中添加了 $stdout.sync = true,输出结果与没有相同。

我也尝试过将 RAILS_ENV=developmentRAILS_ENV=production 附加和前置到预编译任务。

如何让我的 foreman/Procfile 设置成功预编译资产,然后继续启动应用程序的其他任务?

尝试在第一行

之后的每个进程中添加sleep
web: sleep 1; bundle exec puma -e $PUMA_ENV
worker: sleep 1; bundle exec rake jobs:work
search: sleep 1; bundle exec rake sunspot:solr:run

如果有效,请一一删除 sleep 1; 以查看导致问题的原因。

我决定我最好的选择是使用一种语法,该语法将在启动 Puma 之前执行我的 rake assets 任务,并且仅当预编译成功时。

因此,运行命令之间&&的顺序似乎达到了我想要的结果

web: bundle exec rake assets:clean RAILS_ENV=$FOREMAN_ENV && bundle exec rake assets:precompile RAILS_ENV=$FOREMAN_ENV && bundle exec puma -e $FOREMAN_ENV
worker: bundle exec rake jobs:work
search: bundle exec rake sunspot:solr:run

问题在于,只要工头中的一个进程存在,所有进程都存在。我认为这是有道理的设计。该应用程序是 运行ning 服务的组合。

如果你想要运行一次性任务你可以使用工头运行。