Share on Social Media

In this article, you will learn how to setup Ruby on Rails on CentOS 8 and deploy your first Ruby application on the same web server. #centlinux #linux #ruby

What is Ruby on Rails? :

Ruby on Rails, or Rails, is a server-side web application framework written in Ruby and distributed under the MIT License. Rails is a MVC (Model-View-Controller) framework, providing default structures for a database, a web service, and web pages. (Source: Wikipedia)

Ruby on Rails encourages and facilitates the use of web standards such as JSON and XML for data transfer; HTML, CSS and JavaScript for user interfacing.

Also Read: How to install Ruby on Rails on Rocky Linux 9

Environment Specification:

We are using a CentOS 8 minimal installed virtual machine with following specifications.

  • CPU – 3.4 Ghz (2 cores)
  • Memory – 2 GB
  • Storage – 20 GB
  • Operating System – CentOS Linux 8.0
  • Hostname –
  • IP Address – /24

Update Linux Software Packages:

Connect with as root user by using a SSH client.

Before starting any installation, it is a good practice to update your Linux distribution to the latest software packages.

In CentOS, the software packages are uploaded in online yum repositories as soon as they got updated. Therefore, you can easily update your Linux server by using a single dnf command.

# dnf update -y

Install Ruby on Rails Prerequisites:

However, most of the dependencies are automatically resolved by the RVM (Ruby Version Manager) but there are some software packages that you have to install manually.

The first dependency of Ruby on Rails is Git. Git is available in standard yum repository, therefore you can install git on CentOS 8 as follows.

# dnf install -y git

Some components of Ruby on Rails requires Node.js, therefore, you are also required to install it.

Node.js is not available in standard yum repositories. However, Node.js can be installed from NodeSource yum repository.

Add NodeSource yum repository in your Linux server by executing following command.

# curl -sL | bash -

## Installing the NodeSource Node.js 12.x repo...

## Inspecting system...

+ rpm -q --whatprovides redhat-release || rpm -q --whatprovides centos-release || rpm -q --whatprovides cloudlinux-release || rpm -q --whatprovides sl-release
+ uname -m

## Confirming "el8-x86_64" is supported...

+ curl -sLf -o /dev/null ''

## As yum will try to install Node.js from the AppStream repository
instead of the NodeSource repository, the AppStream's version of Node.js has to be disabled.
## Run `sudo yum module enable -y nodejs` to reactivate the AppStream's Node.js repository.

+ yum module disable -y nodejs
Last metadata expiration check: 23:08:51 ago on Sat 25 Apr 2020 12:52:37 PM PKT.
Dependencies resolved.
 Package           Architecture     Version             Repository         Size
Disabling modules:

Transaction Summary


## Downloading release setup RPM...

+ mktemp
+ curl -sL -o '/tmp/tmp.mwRVNDdser' ''

## Installing release setup RPM...

+ rpm -i --nosignature --force '/tmp/tmp.mwRVNDdser'

## Cleaning up...

+ rm -f '/tmp/tmp.mwRVNDdser'

## Checking for existing installations...

+ rpm -qa 'node|npm' | grep -v nodesource

## Run `sudo yum install -y nodejs` to install Node.js 12.x and npm.
## You may also need development tools to build native addons:
     sudo yum install gcc-c++ make
## To install the Yarn package manager, run:
     curl -sL | sudo tee /etc/yum.repos.d/yarn.repo
     sudo yum install yarn

Now, you can install Node.js on CentOS 8 by using dnf command.

# dnf install -y nodejs

Besides Node.js, Ruby on Rails also required YARN (Package Manager). YARN is also provided by its official yum repository. Therefore, you should also add the YARN yum repository in your Linux server.

# curl -sL | tee /etc/yum.repos.d/yarn.repo

name=Yarn Repository 

Now, you can easily install yarn by executing dnf command.

# dnf install -y yarn

Install MariaDB on CentOS 8:

MariaDB Server 10.3 is available in standard yum repository, therefore, you can install it by using dnf command.

# dnf install -y mariadb-server

Enable and start MariaDB database service.

# systemctl enable --now mariadb.service
Created symlink /etc/systemd/system/mysql.service â /usr/lib/systemd/system/mariadb.service.
Created symlink /etc/systemd/system/mysqld.service â /usr/lib/systemd/system/mariadb.service.
Created symlink /etc/systemd/system/ â /usr/lib/systemd/system/mariadb.service.

Configure MariaDB database server and set root user password as follows.

# mysql_secure_installation


In order to log into MariaDB to secure it, we'll need the current
password for the root user.  If you've just installed MariaDB, and
you haven't set the root password yet, the password will be blank,
so you should just press enter here.

Enter current password for root (enter for none):
OK, successfully used password, moving on...

Setting the root password ensures that nobody can log into the MariaDB
root user without the proper authorisation.

Set root password? [Y/n] Y
New password:
Re-enter new password:
Password updated successfully!
Reloading privilege tables..
 ... Success!

By default, a MariaDB installation has an anonymous user, allowing anyone
to log into MariaDB without having to have a user account created for
them.  This is intended only for testing, and to make the installation
go a bit smoother.  You should remove them before moving into a
production environment.

Remove anonymous users? [Y/n] Y
 ... Success!

Normally, root should only be allowed to connect from 'localhost'.  This
ensures that someone cannot guess at the root password from the network.

Disallow root login remotely? [Y/n] Y
 ... Success!

By default, MariaDB comes with a database named 'test' that anyone can
access.  This is also intended only for testing, and should be removed
before moving into a production environment.

Remove test database and access to it? [Y/n] Y
 - Dropping test database...
 ... Success!
 - Removing privileges on test database...
 ... Success!

Reloading the privilege tables will ensure that all changes made so far
will take effect immediately.

Reload privilege tables now? [Y/n] Y
 ... Success!

Cleaning up...

All done!  If you've completed all of the above steps, your MariaDB
installation should now be secure.

Thanks for using MariaDB!

Install RVM on CentOS 8:

RVM (Ruby Version Manager) is a command line tool that allows you to easily install, manage work with multiple Ruby environments from interpreter to set of gems.

You should install RVM on your Ruby on Rails server and later you will install Ruby by using RVM commandline.

RVM is available in its official yum repository. Therefore, you have to add the RVM yum repository in your Linux operating system.

Before adding RVM yum repository, you are required to add the GPG key for the RVM repo as follows.

# gpg --keyserver hkp:// --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDB
gpg: directory '/root/.gnupg' created
gpg: keybox '/root/.gnupg/pubring.kbx' created
gpg: key 105BD0E739499BDB: 8 signatures not checked due to missing keys
gpg: /root/.gnupg/trustdb.gpg: trustdb created
gpg: key 105BD0E739499BDB: public key "Piotr Kuczynski <>" imported
gpg: key 3804BB82D39DC0E3: 108 signatures not checked due to missing keys
gpg: key 3804BB82D39DC0E3: public key "Michal Papis (RVM signing) <>" imported
gpg: no ultimately trusted keys found
gpg: Total number processed: 2
gpg:               imported: 2

If you face problem during installation of GPG key, then you should refer to RVM official website.

Now, you can install RVM as follows.

# curl -sSL | bash -s stable
gpg: Signature made Thu 26 Mar 2020 02:58:42 AM PKT
gpg:                using RSA key 7D2BAF1CF37B13E2069D6956105BD0E739499BDB
gpg: Good signature from "Piotr Kuczynski <>" [unknown]
gpg: WARNING: This key is not certified with a trusted signature!
gpg:          There is no indication that the signature belongs to the owner.
Primary key fingerprint: 7D2B AF1C F37B 13E2 069D  6956 105B D0E7 3949 9BDB
GPG verified '/usr/local/rvm/archives/rvm-1.29.10.tgz'
Creating group 'rvm'
Installing RVM to /usr/local/rvm/
Installation of RVM in /usr/local/rvm/ is almost complete:

  * First you need to add all users that will be using rvm to 'rvm' group,
    and logout - login again, anyone using rvm will be operating with `umask u=rwx,g=rwx,o=rx`.

  * To start using RVM you need to run `source /etc/profile.d/`
    in all your open shell windows, in rare cases you need to reopen all shell windows.
  * Please do NOT forget to add your users to the rvm group.
     The installer no longer auto-adds root or users to the rvm group. Admins must do this.
     Also, please note that group memberships are ONLY evaluated at login time.
     This means that users must log out then back in before group membership takes effect!
Thanks for installing RVM ð
Please consider donating to our open collective to help us maintain RVM.

ð  Donate:

However, you can also install latest stable Ruby and Rails along with the RVM. But we are installing each component separately for the sake of demonstration.

RVM environment script has been copied to /etc/profile.d/ directory. To set the RVM environment for the current session, execute it once.

# source /etc/profile.d/

RVM has been installed on CentOS 8.

Install Ruby on CentOS 8:

Check and resolve any missing prerequisites for Ruby by using the rvm command.

# rvm requirements
Checking requirements for centos.
Installing requirements for centos.
Installing required packages: patch, autoconf, automake, bison, bzip2, gcc-c++, libffi-devel, libtool, make, patch, readline-devel, ruby, sqlite-devel, glibc-headers, glibc-devel........................
Requirements installation successful.

Check list of known versions of Ruby language.

# rvm list known
# MRI Rubies
[ruby-]1.8.7[-head] # security released on head

# for forks use: rvm install ruby-head-<name> --url --branch 2.2

# JRuby

# Rubinius

# TruffleRuby

# Opal

# Minimalistic ruby implementation - ISO 30170:2012

# Ruby Enterprise Edition

# Topaz

# MagLev

# Mac OS X Snow Leopard Or Newer

# IronRuby

Install your required version of Ruby. We are installing MRI Ruby 2.7 as follows.

# rvm install 2.7
Searching for binary rubies, this might take some time.
No binary rubies available for: centos/8/x86_64/ruby-2.7.0.
Continuing with compilation. Please read 'rvm help mount' to get more information on binary rubies.
Checking requirements for centos.
Requirements installation successful.
Installing Ruby from source to: /usr/local/rvm/rubies/ruby-2.7.0, this may take a while depending on your cpu(s)...
ruby-2.7.0 - #downloading ruby-2.7.0, this may take a while depending on your connection...
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100 14.0M  100 14.0M    0     0  1134k      0  0:00:12  0:00:12 --:--:-- 1211k
ruby-2.7.0 - #extracting ruby-2.7.0 to /usr/local/rvm/src/ruby-2.7.0.....
ruby-2.7.0 - #configuring........................................................................
ruby-2.7.0 - #post-configuration..
ruby-2.7.0 - #compiling............................................................................................
ruby-2.7.0 - #installing..................
ruby-2.7.0 - #making binaries executable...
Installed rubygems 3.1.2 is newer than 3.0.8 provided with installed ruby, skipping installation, use --force to force installation.
ruby-2.7.0 - #gemset created /usr/local/rvm/gems/ruby-2.7.0@global
ruby-2.7.0 - #importing gemset /usr/local/rvm/gemsets/global.gems................................................................
ruby-2.7.0 - #generating global wrappers.......
ruby-2.7.0 - #gemset created /usr/local/rvm/gems/ruby-2.7.0
ruby-2.7.0 - #importing gemsetfile /usr/local/rvm/gemsets/default.gems evaluated to empty gem list
ruby-2.7.0 - #generating default wrappers.......
ruby-2.7.0 - #adjusting #shebangs for (gem irb erb ri rdoc testrb rake).
Install of ruby-2.7.0 - #complete
Ruby was built without documentation, to build it run: rvm docs generate-ri

By using RVM, you can install multiple Ruby environments on the same platform. You just need to set a default version of Ruby, that is being used.

Set default version of Ruby language.

# rvm use 2.7 --default
Using /usr/local/rvm/gems/ruby-2.7.0

Verify the current Ruby version.

# ruby --version
ruby 2.7.0p0 (2019-12-25 revision 647ee6f091) [x86_64-linux]

Ruby language has been installed on CentOS Linux 8.

Install Rails on CentOS 8:

Now its time to install Rails on your Linux server. You can do this conveniently by using the gem (Ruby Package Manager).

# gem install rails

Verify installed version of Rails.

# rails -v

Ruby on Rails default service port is 3000/tcp. Therefore, you are required to allow this port in Linux firewall.

# firewall-cmd --permanent --add-port=3000/tcp
# firewall-cmd --reload

Install Ruby Gems:

Install mysql2 gem for Ruby connectivity with MariaDB/MySQL database servers.

# gem install mysql2
Fetching mysql2-0.5.3.gem
Building native extensions. This could take a while...
Successfully installed mysql2-0.5.3
Parsing documentation for mysql2-0.5.3
Installing ri documentation for mysql2-0.5.3
Done installing documentation for mysql2 after 0 seconds
1 gem installed

Bundler provides a consistent environment for Ruby projects by tracking and installing the exact gems and versions that are needed.

You can install Bundler by using the gem command.

# gem install bundler
Fetching bundler-2.1.4.gem
Successfully installed bundler-2.1.4
Parsing documentation for bundler-2.1.4
Installing ri documentation for bundler-2.1.4
Done installing documentation for bundler after 4 seconds
1 gem installed

Your Ruby on Rails server is configured and ready to use now.

Deploy your First Ruby Application:

Create a HelloWorld Project to test your Ruby on Rails environment.

Following command will create the HelloWorld project directory with default skeleton of files and directories.

# rails new HelloWorld -d mysql
ââ serve-index@1.9.1
ââ serve-static@1.14.1
ââ sockjs-client@1.4.0
ââ sockjs@0.3.19
ââ spdy-transport@3.0.0
ââ spdy@4.0.2
ââ thunky@1.1.0
ââ type-is@1.6.18
ââ unpipe@1.0.0
ââ utils-merge@1.0.1
ââ wbuf@1.7.3
ââ webpack-dev-middleware@3.7.2
ââ webpack-dev-server@3.10.3
ââ websocket-extensions@0.1.3
ââ ws@6.2.1
ââ yargs-parser@11.1.1
ââ yargs@12.0.5
Done in 11.72s.

Set MariaDB database credentials in the database.yml file.

# cd HelloWorld
# vi config/database.yml

Under the default configurations set the root user password.

default: &default
  adapter: mysql2
  encoding: utf8mb4
  pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
  username: root
  password: 123 # Set the MariaDB Password here
  socket: /var/lib/mysql/mysql.sock

Create the database for your Ruby project by using rake command.

# rake db:create
/usr/local/rvm/gems/ruby-2.7.0/gems/actionpack- warning: Using the last argument as keyword parameters is deprecated; maybe ** should be added to the call
/usr/local/rvm/gems/ruby-2.7.0/gems/actionpack- warning: The called method `initialize' is defined here
Created database 'HelloWorld_development'
Created database 'HelloWorld_test'

Start your Ruby on Rails application.

# rails server -b
Warning: the running version of Bundler (2.1.2) is older than the version that created the lockfile (2.1.4). We suggest you to upgrade to the version that created the lockfile by running `gem install bundler:2.1.4`.
The dependency tzinfo-data (>= 0) will be unused by any of the platforms Bundler is installing for. Bundler is installing for ruby but the dependency is only for x86-mingw32, x86-mswin32, x64-mingw32, java. To add those platforms to the bundle, run `bundle lock --add-platform x86-mingw32 x86-mswin32 x64-mingw32 java`.
Warning: the running version of Bundler (2.1.2) is older than the version that created the lockfile (2.1.4). We suggest you to upgrade to the version that created the lockfile by running `gem install bundler:2.1.4`.
=> Booting Puma
=> Rails application starting in development
=> Run `rails server --help` for more startup options
/usr/local/rvm/gems/ruby-2.7.0/gems/actionpack- warning: Using the last argument as keyword parameters is deprecated; maybe ** should be added to the call
/usr/local/rvm/gems/ruby-2.7.0/gems/actionpack- warning: The called method `initialize' is defined here
Puma starting in single mode...
* Version 4.3.3 (ruby 2.7.0-p0), codename: Mysterious Traveller
* Min threads: 5, max threads: 5
* Environment: development
* Listening on tcp://
Use Ctrl-C to stop

Open URL in a web browser.

Ruby on Rails Default Homepage

Conclusion – Setup Ruby on Rails:

You have successfully setup Ruby on Rails Server on CentOS 8. If you wish to learn more about the Ruby on Rails, then you should attend Ruby on Rails 6 Complete Beginner’s Course [2020] at Udemy or read Agile Web Development with Rails 6 (PAID LINK) by Pragmatic Bookshelf.

Leave a Reply

Your email address will not be published. Required fields are marked *