How to Install Ruby on macOS with RVM

This article explains why you should avoid using the version of Ruby bundled with macOS and should instead install your own version of Ruby with RVM, the Ruby Version Manager.

Hands Off the System Ruby

Apple bundles the Ruby programming language with macOS. However, the main caveat for using the bundled version, called the system Ruby, is that Apple bundles Ruby for it’s own use. Therefore, it’s best not to make changes to the system Ruby.

You’ll know when you’re about to change the system Ruby when you need to prefix a gem installation with sudo, for example:

sudo gem install jekyll

Another reason for not using the system Ruby is that it’s often several versions behind the latest stable version.

The Ruby Version Manager

A better alternative to using the system Ruby is to install Ruby with RVM, the Ruby Version Manager. RVM is a tool for installing different versions of Ruby itself. RVM has the following advantages:

  1. RVM enables you to install multiple versions of Ruby and allows you to change which version you want to use.
  2. RVM installs each version of Ruby in a hidden folder in your home folder so each version of Ruby you install doesn’t affect the system Ruby.
  3. Gems installed by RVM-managed versions of Ruby are installed within the hidden folder in your home folder containing that version of Ruby.
  4. You won’t need use sudo to install gems.

To check that you’re currently using the system Ruby, open Terminal and type the following:

which ruby

If you’re using the system Ruby, macOS will respond with:

/usr/bin/ruby

You can check which version of Ruby macOS is using with:

ruby -v

Installing RVM and Ruby

The RVM install page has comprehensive instructions for installing RVM that work on macOS. I’ll provide the steps I used here.

The first step is to install the mpapis public key. However, as the install page notes, you might need gpg. macOS doesn’t ship with gpg so before installing the public key, you’ll need to install gpg. I installed gpg with Homebrew:

brew install gnupg

After you’ve installed gpg, you can install the mpapis public key:

gpg --keyserver hkp://keys.gnupg.net
    --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3

I've listed the mapis public key install command here for illustration. You should use the version on the RVM install page.

I chose to install RVM with the latest stable version of Ruby, which at the time was 2.2.0:

\curl -sSL https://get.rvm.io | bash -s stable --ruby

After the installation completes, close the Terminal window and open a new one to make sure that Terminal picks up any environment changes.

Using RVM

You can list the versions of Ruby available to RVM with rvm list:

rvm rubies

=* ruby-2.2.0 [ x86_64 ]

# => - current
# =* - current && default
#  * - default

The rvm use command selects a version of Ruby:

rvm use 2.2.0

You can check that you’re using an RVM-managed version of Ruby with:

which ruby

macOS now responds with:

/Users/jeff/.rvm/rubies/ruby-2.2.0/bin/ruby

which tells us we’re using version 2.2.0 and that version 2.2.0 has been installed in my home folder away from the system Ruby. You can confirm this by asking Ruby itself with:

ruby -v

The RVM-managed version of Ruby responds with:

ruby 2.2.0p0 (2014-12-25 revision 49005) [x86_64-darwin14]

As I mentioned earlier, gems installed with RVM-managed versions of Ruby are located with the Ruby. You can check where gems will be installed with:

gem env

The following lines of output shows that gems will be installed in the folder XXX.

- GEM PATHS:
   - /Users/jeff/.rvm/gems/ruby-2.2.0
   - /Users/jeff/.rvm/gems/ruby-2.2.0@global

To find out where a particular gem is installed, use the gem which command. For example, gem which jekyll locates the Jekyll gem:

/Users/jeff/.rvm/gems/ruby-2.2.0/gems/jekyll-2.5.3/lib/jekyll.rb