架构超时包含在Gemfile中,但我们只希望它作为生产中的中间件。因此,在初始化程序中,我们有:
config.middleware.delete Rack::Timeout
在此行之前和之后检查显示从阵列中删除了rack-timeout。无论如何,请求仍然超时,宝石中的快速“放置”表明它确实是罪魁祸首。
这是因为在调用delete之前已经构建了中间件堆栈吗?或者在每个请求中读取堆栈?如果是这样的话,可能是什么问题?
答案 0 :(得分:8)
为什么不具备以下内容?
group :production do
gem "rack-timeout"
end
理论上,初始化程序中的中间件删除应该在服务器重启后处理问题,假设您正在讨论将某些内容放入config/initializers/
。
进行了一些实验并将其放入config/initializers/rack-timeout.rb
:
if Rails.env.production?
Rack::Timeout.timeout = 0.5
else
Rails.configuration.middleware.delete Rack::Timeout
end
这是一个脚手架控制器:
sleep 1
重新启动开发服务器后,一切看起来都很酷(看不到超时:D)。所以,也许只是一个糟糕的变量。
我仍然认为使用仅限制作组是更好的解决方案。
在OSX上运行Rails 3.2.2和ruby 1.9.2-p290。