8

在尝试启动工头之后,我收到了这个错误(请注意,它似乎确实适用于 heroku,所以我猜这是一个严格的本地问题):

hrn039:textthechange jon$ foreman start
02:20:00 web.1     | started with pid 7363
02:20:01 web.1     | /Users/jon/.rvm/gems/ruby-1.9.3-p0/gems/railties-3.2.1/lib/rails/commands/server.rb:33:in `parse!': missing argument: -e (OptionParser::MissingArgument)
02:20:01 web.1     |    from /Users/jon/.rvm/gems/ruby-1.9.3-p0/gems/rack-1.4.1/lib/rack/server.rb:280:in `parse_options'
02:20:01 web.1     |    from /Users/jon/.rvm/gems/ruby-1.9.3-p0/gems/rack-1.4.1/lib/rack/server.rb:180:in `options'
02:20:01 web.1     |    from /Users/jon/.rvm/gems/ruby-1.9.3-p0/gems/railties-3.2.1/lib/rails/commands/server.rb:54:in `set_environment'
02:20:01 web.1     |    from /Users/jon/.rvm/gems/ruby-1.9.3-p0/gems/railties-3.2.1/lib/rails/commands/server.rb:42:in `initialize'
02:20:01 web.1     |    from /Users/jon/.rvm/gems/ruby-1.9.3-p0/gems/railties-3.2.1/lib/rails/commands.rb:50:in `new'
02:20:01 web.1     |    from /Users/jon/.rvm/gems/ruby-1.9.3-p0/gems/railties-3.2.1/lib/rails/commands.rb:50:in `<top (required)>'
02:20:01 web.1     |    from script/rails:6:in `require'
02:20:01 web.1     |    from script/rails:6:in `<main>'
02:20:01 web.1     | process terminated
02:20:01 system    | sending SIGTERM to all processes

Procfile 只有一行由 heroku 指定

web: bundle exec rails server thin -p $PORT -e $RACK_ENV

我的gemfile有

gem 'thin'

谷歌对这个错误不是很有帮助。

谢谢!

4

3 回答 3

21

这与在 Heroku 上执行无关 - 请参阅关于使用 Foreman 执行的原始问题 - 这是本地执行。

您可以通过执行以下操作来复制您的错误:

导轨服务器瘦-e

鉴于您的 Procfile,这实际上就是 Foreman 正在运行的内容:

网络:捆绑 exec rails 服务器瘦 -p $PORT -e $RACK_ENV

所以我猜你没有将参数传递给-e。IE。您还没有在本地定义 RACK_ENV 。

您可以做的是.env在本地目录中创建一个文件,例如

RACK_ENV=开发

端口=3000

.env在根据您的流程类型声明创建流程之前,Foreman 将自动选择本地文件并适当地设置环境。

于 2012-04-04T13:41:02.807 回答
0

我刚刚遇到了同样的问题。如果您将 Procfile 更改为

web: bundle exec rails server thin -p $PORT

它应该工作。请注意,这使用默认的瘦端口 5000 而不是 3000(这意味着您需要转到http://localhost:5000才能查看您的应用程序。

刚刚

web: bundle exec rails server thin

在您的 Procfile 中将使用端口 3000,但这会导致 Heroku 出错。

于 2012-04-03T19:15:50.657 回答
0

我在 Ubuntu 10.04 中使用 rails v3.2 时遇到了同样的问题。通过执行以下步骤,我设法瘦身:

  1. 更改您的 Procfile 如下:

    web: 捆绑 exec rails server thin -p $PORT -e development

  2. 在 config.ru 文件的顶部添加$stdout.sync = true,将服务器输出定向到终端(否则您不会在终端中获得输出)

告诉我它是否有效!

于 2012-03-19T19:14:12.870 回答