Working with chruby and nvm on Ubuntu
I am setting up a new Ubuntu 16.04 dev environment. I wanted to take some notes on my progress. I am trying out chruby after it being highly recommended by the ruby gurus Eric and Zach. A natural place to start would be to get this Jekyll blog running locally. I ran into a few stumbling blocks.
Installing chruby and a Ruby version
There are many different ways to do this, I chose the method below.- Download and Install chruby
wget -O chruby-0.3.9.tar.gz https://github.com/postmodern/chruby/archive/v0.3.9.tar.gz tar xf chruby-0.3.9.tar.gz cd chruby-0.3.9/ sudo make install - Add chruby to your .bashrc
source /usr/local/share/chruby/chruby.sh source /usr/local/share/chruby/auto.sh - Install dependencies
sudo apt-get install -y build-essential bison zlib1g-dev \ libyaml-dev libssl-dev libgdbm-dev libreadline-dev \ libncurses5-dev libffi-dev - Install Ruby 2.3.1 This will work for any version of Ruby, but 2.3.1 is the one that I needed.
wget https://cache.ruby-lang.org/pub/ruby/2.3/ruby-2.3.1.tar.bz2 tar xf ruby-2.3.1.tar.bz2 cd ruby-2.3.1/ ./configure --prefix=/opt/rubies/ruby-2.3.1 make sudo make install - Install Gems for Jekyll Now that we have Ruby installed, we can install bundler and install all of our Gems.
chruby 2.3.1 gem install bundle bundle install
/home/levlaz/.gem/ruby/2.3.1/gems/bundler-1.12.5/lib/bundler/runtime.rb:89:in
`rescue in block (2 levels) in require': There was an error while trying to load
the gem 'jekyll-coffeescript'. (Bundler::GemRequireError)
Gem Load Error is: Could not find a JavaScript runtime. See
https://github.com/rails/execjs for a list of available runtimes.
Since I often work with many different versions of node, I took the opportunity to install nvm rather than the version of node that is available in the Ubuntu repositories.
Installing nvm
nvm is a really nice tool for working with various versions of node.- Run the installer script
This will install nvm and add the appropriate lines to yourcurl -o- https://raw.githubusercontent.com/creationix/nvm/v0.31.7/install.sh | bash~/.bashrcfile in order to load properly. - Install the latest version of node
nvm install node - Source NVM To get nvm working in the same terminal, you can run
source ~/.bashrc, alternatively you can open a new terminal and nvm will automatically be sourced since the installer script added the appropriate bits for us.
jekyll -s. Not only do we have Jekyll running like a charm, we also are ready to work with any version of Ruby or Node with chruby and nvm.
Thank you for reading! Share your thoughts with me on bluesky, mastodon, or via email.
Check out some more stuff to read down below.
Most popular posts this month
- 2025
- My Custom Miniflux CSS Theme
- Setting up ANTLR4 on Windows
- 2024
- Convert Markdown to PDF in Sublime Text
Recent Favorite Blog Posts
This is a collection of the last 8 posts that I bookmarked.
- Fedora Magazine: Contribute to Fedora 44 KDE and GNOME Test Days from Fedora People
- Pluralistic: bunnie's piggyback hack (09 Jan 2026) from Pluralistic: Daily links from Cory Doctorow
- Clicks Communicator from Chris Hannah
- A Year Of Vibes from Armin Ronacher's Thoughts and Writings
- Pluralistic: A perfect distillation of the social uselessness of finance (18 Dec 2025) from Pluralistic: Daily links from Cory Doctorow
- Moving from WordPress to Substack from charity.wtf
- Grow, Like a Tree Not a Cancer from Jim Nielsen’s Blog
- Pluralistic: All the books I reviewed in 2025 (02 Dec 2025) from Pluralistic: Daily links from Cory Doctorow
Articles from blogs I follow around the net
Doing less, for her
My daughter will be born soon, and I’m reflecting on what that means for my OpenSource work.
via Carlos Becker February 1, 2026The Browser’s Little White Lies
So I’m making a thing and I want it to be styled different if the link’s been visited. Rather than build something myself in JavaScript, I figure I’ll just hook into the browser’s mechanism for tracking if a link’s been visited (a sensible approach, if I d…
via Jim Nielsen’s Blog February 1, 2026$29 million stolen from from Step Finance treasury wallets
The Solana-based defi portfolio tracker Step Finance lost 261,854 SOL (~$28.7 million) when a thief gained access to treasury and fee wallets. It's not yet clear how the attacker was able to steal the funds, although Step Finance…
via Web3 is Going Just Great February 1, 2026Generated by openring