如何理解为什么ruby进程阻止100%CPU

Har*_*tor 8 ruby ruby-on-rails passenger

我们有一个很大的rails应用程序,并且几天之后,我们的ruby进程似乎在一个循环中阻塞并吃100%的CPU,直到乘客服务器死于502错误.

你知道找出原因的最佳方法吗?

我尝试过New Relic,但它只是性能的东西,我们的错误太多,无法猜测是什么问题.(我们每天都有很多请求和很多UTF-8 BSON错误,因为我们使用的是UTF-8网址)

使用:

  • Rails 3.2.6与Ruby 1.9.2p290
  • 乘客3.0.13
  • MongoDB 2.0.1与Mongoid 2.4.11
  • Nginx的
  • FreeBSD 8.2

dbe*_*hur 8

一个方便的方法来找出你的红宝石卡在哪里是附加gdb到正在运行的过程和call rb_backtrace().这会将当前堆栈跟踪打印到stderr,这可能会定向到日志文件.这是我在博客上找到的一小段步行路程.堆栈跟踪应该可以帮助您本地化您的进程停滞的位置,并允许您通过代码检查或通过在关键代码路径周围添加日志记录工具来确定正在进行的操作.

Aman Gupta有一个gdb到ruby hooks库gdb.rb我有时发现它很方便.