ruby-on-rails - 如何在 Rails 3.2 中找到 "SystemStackError (stack level too deep)"的来源

标签 ruby-on-rails ruby debugging

我从 Rails 3.0 迁移到 3.2。

当我尝试显示页面时出现错误,只有这个小堆栈跟踪:

    SystemStackError in UserController#show

    stack level too deep
    SystemStackError (stack level too deep):
      activesupport (3.2.1) lib/active_support/callbacks.rb:415


      Rendered /home/barbacan/.rvm/gems/ruby-1.9.2-head/gems/actionpack-3.2.1/lib/action_dispatch/middleware/templates/rescues/_trace.erb (55.3ms)
      Rendered /home/barbacan/.rvm/gems/ruby-1.9.2-head/gems/actionpack-3.2.1/lib/action_dispatch/middleware/templates/rescues/_request_and_response.erb (4.0ms)
      Rendered /home/barbacan/.rvm/gems/ruby-1.9.2-head/gems/actionpack-3.2.1/lib/action_dispatch/middleware/templates/rescues/diagnostics.erb within rescues/layout (61.4ms)

日志并不冗长。

这个问题出现在回调中:它是动态代码,很难调试。

您是否知道可以帮助我调试并找到问题根源的工具或方法?

谢谢!

编辑:

在 Ruby/RoR 中,有一种方法可以将所有调用的方法列为列表吗?

最佳答案

您可以尝试使用 Pry和 railscast 在 http://railscasts.com/episodes/280-pry-with-rails , 然后您可以在可能的位置设置断点并手动逐步执行。

关于ruby-on-rails - 如何在 Rails 3.2 中找到 "SystemStackError (stack level too deep)"的来源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9192148/

相关文章:

mysql - 如何在 Ruby on Rails 4 中创建比其父级具有更多属性的继承模型?

ruby-on-rails - 如何从Rails中的Elasticsearch检索所有记录

c++ - Qt 调试库的使用

android - 如何阻止应用程序在崩溃时重新启动并使崩溃可见?

php - 如何检查 file_get_contents 在 PHP 中返回 false 的原因

ruby-on-rails - 如何在simple_form中用div包围输入而不包围它们各自的标签(使用f.input)

ruby-on-rails - 无法批量分配 protected 属性错误

ruby-on-rails - 如何使虚拟属性成为 bool 字段

ruby - 导轨 4 : auto load from lib

ruby - 如何在当前上下文中评估另一个类的方法?