【问题标题】:'foreman start' is stuck“工头开始”卡住了
【发布时间】:2012-05-25 19:20:30
【问题描述】:

我有一个本地开发的 Rails 应用程序。它非常简单,没有数据库,只有一个控制器,它访问 Facebook 数据并将它们呈现在视图中。顺便说一下,使用了gem RestGraph

在我将这个应用程序推送到 Heroku 之前,我使用 foreman start 对其进行了测试。由于我在需要安装“瘦”gem 并创建一个 Procfile 之前使用的是 WEBrick:

web: bundle exec thin start -R config.ru -e $RACK_ENV -p $PORT

似乎还需要一个“.env”文件,内容如下:

RACK_ENV=development
PORT=3000

'config.ru'文件由rails生成,内容如下:

require ::File.expand_path('../config/environment',  __FILE__)
run Myapp::Application

现在我输入了“工头开始”,但我得到的只是一行:

15:33:18 web.1     | started with pid 27143

服务器不会启动。如果我强制终止它,错误是:

/usr/local/foreman/lib/foreman/engine.rb:141: [BUG] rb_sys_fail() - errno == 0

这不是很有帮助。

【问题讨论】:

标签: ruby-on-rails ruby facebook heroku


【解决方案1】:

您的日志可能只是被缓冲而不是“卡住”:foreman only shows line with “started wit pid #” and nothing else

我通过添加解决了这个问题

$stdout.sync = true

到 config.ru

那么您可能会从 Foreman 那里获得更多有用的反馈。

【讨论】:

  • 这对我有用。当我对卡住的工头执行 ctrl-C 时,我也把其余的线吐出来了。
【解决方案2】:

这似乎有点过于复杂。通过查看几个应用程序,我的 procfile 中有以下内容:

bundle exec rails server thin -p $PORT

在这些情况下,我也没有.env 文件。

值得注意的一点是,Foreman 大部分时间都会忽略你经过的端口,它喜欢坐在高于 5000 的端口范围内

【讨论】:

    猜你喜欢
    • 2015-09-25
    • 1970-01-01
    • 2013-10-22
    • 1970-01-01
    • 1970-01-01
    • 2012-06-23
    • 2021-10-08
    • 2016-11-24
    • 1970-01-01
    相关资源
    最近更新 更多