JRuby 1.0已經來了,可以在JVM上面運行Rails,你還等什麼。
使用jprofiler監控jruby腳本
jruby本質上也是啟動一個jvm,然後去讀ruby腳本並解釋執行(也可以編譯),因此jprofiler理所當然也可以去監控jruby腳本的執行。
執行
jruby hello.rb等價於執行:
java -xmx378m -xss1024k -djruby.home=/usr/local/jruby
-djruby.lib=/usr/local/jruby/lib djruby.script=jruby org.jruby.main hello.rb這一點,你可以通過ps aux |grep jruby 看到。因此配置jprofiler就簡單了,在vm arguments加上這些參數(可以包括jruby的參數),比如我的vm arguments配置如下:
-server -xmx378m -xss1024k -djruby.script=jruby -djruby.thread.pooling=true
-djruby.jit.threshold=0 -djruby.compile.fastest=true
-djruby.home=d:jrubyjruby-1.1rc2 -djruby.lib=d:jrubyjruby-1.1rc2lib
main class or executable jar填上:org.jruby.main。然後就是arguments一欄填上你的腳本位置:
d:rubylibhello.rb
最後,別忘了將jruby/lib目錄下的bsf.jar和jruby.jar加入class path。
大功告成,你可以用jprofiler去觀察gc、執行緒和鎖、heap等等了。