config.mIDdleware.delete Rack::Timeout
检查此行之前和之后显示从阵列中删除了机架超时.无论如何,请求仍然超时,宝石中的快速“放置”表明它确实是罪魁祸首.
这是因为在调用delete之前已经构建了中间件堆栈吗?或者在每个请求中读取堆栈?如果是这样的话,可能是什么问题?
解决方法 为什么不只是像下面这样的东西?group :production do gem "rack-timeout"end
从理论上讲,初始化程序中的中间件删除应该在服务器重启后处理问题,假设你正在谈论在config / initializers /中放置一些东西.
做了一些实验并将其放入config / initializers / rack-timeout.rb:
if Rails.env.production? Rack::Timeout.timeout = 0.5else Rails.configuration.mIDdleware.delete Rack::Timeoutend
这在一个脚手架控制器中:
sleep 1
重新启动开发服务器后,一切看起来都很酷(看不到超时:D).所以,也许只是一个糟糕的变量.
我仍然认为使用仅限生产组是更好的解决方案.
在OSX上使用Rails 3.2.2和ruby 1.9.2-p290.
总结以上是内存溢出为你收集整理的ruby-on-rails – 中间件如何被删除?全部内容,希望文章能够帮你解决ruby-on-rails – 中间件如何被删除?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)