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