Jan 24 2010

How to Install RVM and Rails 3 on Snow Leopard

Ruby Mac Rails | comments

This is a continuation of my post on installing Ruby version manager or multiple versions of Ruby for Unix. This time it's about OS X 10.6.1 or the Snow Leopard.

Snow Leopard includes Ruby and Rails by default if you install XCode. The version is 1.8.7 and 2.2.2 for each, respectively. This would not suffice for most developers because we need to start porting to Ruby 1.9 and start experimenting with Rails 3. The goal is to just keep moving forward and use the best version that exists.

Update: Since I am getting a lot of feedback regarding this post. I noticed it's not newbie-friendly. Sorry. Here are the missing steps.

My Apache2 is installed in /usr/local and PHP5 is compiled by source. I do not use what Leopard has by default because it wasn't working well for me.

In case it happens for you and you want to install PHP5 and more modules. See the following guides:

Compiling Apache in 64-bits Mode on Leopard


Installing PHP


Starting Apache at boot on Leopard


I also installed Fink

So at the very least, you can skip reading what's written on the links above if your Apache2 installed is OK.

Install WGET (but you can also use curl) or just download via web browser.

              tar -xzvf wget-latest.tar.gz
              cd wget-1.11.4/
              ./configure
              make
              sudo make install
              

Install Readline

              wget ftp://ftp.cwru.edu/pub/bash/readline-6.0.tar.gz
              tar -xvzf readline-6.0.tar.gz
              cd readline-6.0
              ./configure
              make
              sudo make install
              

Install Most

              wget ftp://space.mit.edu/pub/davis/most/most-5.0.0.tar.gz
              tar xvzf most-5.0.0.tar.gz
              cd most-5.0.0
              ./configure
              make
              sudo make install
              

RVM installation for OS X.

Please read the guides on the website of Wayne. Click here to go there.

Note: The path "/usr/local" is important. This makes a bit of a difference between installing on Ubuntu/Debian and OS X.

              sudo gem install rvm #install rvm 
              rvm-install 
              rvm install 1.8.7 -C --enable-shared,--with-readline-dir=/usr/local
              rvm install 1.9.1 -C --enable-shared,--with-readline-dir=/usr/local
              rvm install 1.9.2 -C --enable-shared,--with-readline-dir=/usr/local
              rvm 1.8.7 --default
              

Install Prerequisites

Git

Hivelogic tutorials are good. Check out how to install Git on Leopard.

SQLite 3

              wget http://www.sqlite.org/sqlite-amalgamation-3.6.22.tar.gz
              tar xvzf sqlite-amalgamation-3.6.22.tar.gz
              cd sqlite-3.6.22/
              ./configure
              make
              sudo make install
              

MySQL

Download from MYSQL website

Select the version compatible with your Mac.

              sudo /Library/StartupItems/MySQLCOM/MySQLCOM start
              

Install Rails 3.0 Pre

              rvm use 1.8.7%rails3 
              gem install rake rack test-spec thor sqlite3-ruby 
              gem install mysql -- --with-mysql-dir=/usr/local/mysql    
              git clone git://github.com/rails/rails.git && cd rails
              rake package && gem install -f */pkg/*.gem pkg/*.gem  
              cd arel && thor :build && thor :install 
              cd ~
              
              

And all this didn't take time for me even while writing this post. I now have a successful install for Rails 3 Pre. Same result with Ubuntu Karmic Koala.

              
              Katherine-Pes-iMac:~ katz$ rails -v
              Rails 3.0.pre
              
              rails new yourawesomeapp -d mysql 
              

I suggest replacing the .gitignore file immediately with the .gitignore you've been using or add those necessary entries.

An example of a complete .gitignore file is here.

But often this is just what you need:

              *~
              .#*
              .DS_Store
              backups/* #[I keep some files relevant to the application like the database dump on the same folder] 
              log/* #[we don't need the the log files submitted
               
              

Keep adding in other entries later.

Update:

Install Rails 3 Beta

              gem install tzinfo builder memcache-client rack rack-test rack-mount erubis mail text-format thor bundler i18n
              gem install rails --pre
              

Some guides out there are wrong. Do not use "sudo" when you are using RVM. Your gems are on your user's home directory.

If things are not working and you have followed installation guides. You're missing an important part which is called the .bash_profile. Please review your .bash_profile first. I can't explain every line but every line is important.

This is what I have right now:

              Katherine-Pes-iMac:~ katz$ cat .bash_profile
              
              export PATH=/usr/local/bin/:/usr/local/sbin/:/opt/local/bin/:/opt/local/sbin/
              :/Users/katz/.rvm/rubies/ruby-1.8.7-p248/bin:
              /Users/katz/.rvm/gems/ruby-1.8.7-p248/bin:
              /Users/katz/.rvm/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/usr/X11/bin
              export PATH="/usr/local/bin:/usr/local/sbin:
              /usr/local/mysql/bin:$PATH" 
              
              export APACHE2="/usr/local/apache2/bin"
              export PATH="${APACHE2}:${PATH}"
              
              export EDITOR='mate -w'
              export CLICOLOR=1
              
              export LSCOLORS=ExFxCxDxBxegedabagacad
              export PAGER=most
              
              if [[ -s /Users/katz/.rvm/scripts/rvm ]] ; then source /Users/katz/.rvm/scripts/rvm ; fi
              
              
              alias start_mysql="/Library/StartupItems/MySQLCOM/MySQLCOM start"
              alias stop_mysql="/Library/StartupItems/MySQLCOM/MySQLCOM stop"
              
              . /sw/bin/init.sh
              
              function gemdir {
              if [[ -z "$1" ]] ; then
              echo "gemdir expects a parameter, which should be a valid rvm Ruby selector"
              else
              rvm "$1"
              cd `rvm gemdir`
              pwd
              fi
              }
              
              

As you can see, there's RVM code. If you follow RVM installation properly you should have something like that. Aliases are shortcuts for starting/stopping MYSQL but mine is automatically loaded on startup.

Have fun :)