# rbenv

# 1. Install and manage versions of Ruby with rbenv

The easiest way to install and manage various versions of Ruby with rbenv is to use the ruby-build plugin.

First clone the rbenv repository to your home directory:

$ git clone https://github.com/rbenv/rbenv.git ~/.rbenv

Then clone the ruby-build plugin:

$ git clone https://github.com/rbenv/ruby-build.git ~/.rbenv/plugins/ruby-build

Ensure that rbenv is initialized in your shell session, by adding this to your .bash_profile or .zshrc:

type rbenv > /dev/null
if [ "$?" = "0" ]; then
    eval "$(rbenv init -)"
fi

(This essentially first checks if rbenv is available, and initializes it).

You will probably have to restart your shell session - or simply open a new Terminal window.

Note: If you're running on OSX, you will also need to install the Mac OS Command Line Tools with:

$ xcode-select --install

You can also install rbenv using Homebrew (opens new window) instead of building from the source:

$ brew update
$ brew install rbenv

Then follow the instructions given by:

$ rbenv init

Install a new version of Ruby:

List the versions available with:

$ rbenv install --list

Choose a version and install it with:

$ rbenv install 2.2.0

Mark the installed version as the global version - i.e. the one that your system uses by default:

$ rbenv global 2.2.0

Check what your global version is with:

$ rbenv global
=> 2.2.0

You can specify a local project version with:

$ rbenv local 2.1.2
=> (Creates a .ruby-version file at the current directory with the specified version)

Footnotes:

[1]: Understanding PATH (opens new window)

# Uninstalling a Ruby

There are two ways to uninstall a particular version of Ruby. The easiest is to simply remove the directory from ~/.rbenv/versions:

$ rm -rf ~/.rbenv/versions/2.1.0

Alternatively, you can use the uninstall command, which does exactly the same thing:

$ rbenv uninstall 2.1.0

If this version happens to be in use somewhere, you'll need to update your global or local version. To revert to the version that's first in your path (usually the default provided by your system) use:

$ rbenv global system