Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Rails 3 - Speed up Console Loading Time

I am wondering if there is any relatively easy way to speed up my console load time, which is starting to approach 30 seconds. I have a lot of subclasses whose methods don't seem to be affected by reload! so I end up opening and closing the console a lot. IRB loads lightning quick.

Do I have too many gems? How do I go about timing the load tasks so I can see what is taking up the most time? As you can see, I've already tried the dev-boost gem to no avail. The app is fine in Passenger, it's just the console loading that bugs the crap out of me. Running on MBP OSX 10.6.6 with 2.4GHz and 4GB RAM. Not using RVM.

Versions:

Ovid$ rails -v Rails 3.0.3 Ovid$ ruby -v ruby 1.9.2p136 (2010-12-25 revision 30365) [x86_64-darwin10] 

Memory:

Ovid$ vm_stat Mach Virtual Memory Statistics: (page size of 4096 bytes) Pages free:                         118818. Pages active:                       341320. Pages inactive:                      99490. Pages speculative:                  310576. Pages wired down:                   112527. "Translation faults":             23097323. Pages copy-on-write:               1270961. Pages zero filled:                13836659. Pages reactivated:                      36. Pageins:                            165761. Pageouts:                                0. Object cache: 28 hits of 760846 lookups (0% hit rate) 

Gemfile:

source 'http://rubygems.org'  gem 'rails', '3.0.3' gem 'mysql2' gem 'foreigner' gem 'haml' gem 'capistrano' gem 'nokogiri'  #web services gem 'yammer4r' gem 'ruby-freshbooks'  #authentication gems from nifty generator gem "bcrypt-ruby", :require => "bcrypt" gem "mocha", :group => :test gem 'authlogic'  #dev group :development do   gem 'rails-dev-boost', :git => 'git://github.com/thedarkone/rails-dev-boost.git', :require => 'rails_development_boost' end  #testing group :test do   gem 'database_cleaner'   gem 'cucumber-rails'   gem 'cucumber'   gem 'rspec-rails'   gem 'spork'   gem 'launchy'   gem 'machinist'   gem 'faker'   gem 'capybara' end 

Thank you very much!

like image 928
pendevere Avatar asked Jan 19 '11 14:01

pendevere


1 Answers

I finally found my startup bottlenecks using Benchmark. In particular, navigate to the bundler gem and in lib/bundler/runtime.rb, find the line that does Kernel.require and wrap it like this:

puts Benchmark.measure("require #{file}") {   Kernel.require file }.format("%n: %t %r") 

You may have to add require 'benchmark' somewhere in your app, like in config/boot.rb. That will show you how long it takes to require each gem. I can't guarantee your results will match mine, but I had a few gems that were taking over a second to load compared with sub-millisecond for most. A few were gems that I didn't need for developing but I did need for some tasks in the development environment, e.g. capistrano, shoulda. I benchmarked other areas of startup (initializers, etc), but couldn't find any significant bottlenecks.

I haven't yet figured out a clean way to configure the app to only load those for tasks where they are really needed. Possibly, I could create an environment called :speedy and use RAILS_ENV=speedy rails s/c for startup when I know I don't need those gems. Then in Gemfile, I could use group :speedy to exclude those gems in certain cases.

All that said, the biggest startup annoyance for me is having to load the entire environment to run a rake task. I could probably exclude most gems for that, but Gemfile would start to get messy so I don't know if it's worth it.

like image 180
Brian Deterling Avatar answered Oct 08 '22 04:10

Brian Deterling