DEV Community

Cover image for Saying "Hello world" with Ruby on Rails
Lazarus Lazaridis
Lazarus Lazaridis

Posted on

Saying "Hello world" with Ruby on Rails

If you are new to Ruby I suggest you first read this which in short explains why you should not give up on learning Ruby.

In this post we will do the first steps in order to get familiar with both the language (Ruby) and the framework (Ruby on Rails). The post is based on my own experience back then, so I hope that anyone new here can understand them easily.

First things first, install ruby and rails on your machine. There are plenty of installation tutorials out there from which you can pick the one matching your machine's operating system. I followed this one in order to install Ruby 2.0 & Rails 4 on OS X Mavericks.

Development environment

You will need:

  • Text editor: I prefer using GitHub's Atom which is an excellent IDE many plugins. There are a lot of other options but this is something you don't have to decide now. Give them a try and you'll find the one you like the most.

  • Console: I use iTerm2 which is a powerful replacement for OS X's Terminal application. Find a terminal application for your OS and spend some time customizing to match your preferences, you'll be working a lot in it.

  • Browser: Your favorite one. I use Chrome or Firefox for development. Well, I used to prefer Chrome but after the release of Firefox Quantum, I can't decide who's the best so I use them both.

Let's begin

Create a folder in which you are going to put the tutorial's code and navigate to it from the command line:

mkdir tutorials
cd tutorials
Enter fullscreen mode Exit fullscreen mode

Now let's create our new application with the name hello_world:

rails new hello_world
Enter fullscreen mode Exit fullscreen mode

The command above will create a folder with the name hello_world.
Inside this folder you will find various files and subfolders which actually constitute a Rails application.

In this post I will only explain the files/folders to which we are going to make changes on (a thorough explanation will be provided in an upcoming one).

You already have a web server installed in your system that comes bundled with Ruby and its name is WEBRick. Let's start it to see what we have created with the last command.

From the command line, navigate to the created folder:

cd hello_world
Enter fullscreen mode Exit fullscreen mode

Start WEBrick with the following command:

rails server
Enter fullscreen mode Exit fullscreen mode

You can also use s instead of server in the previous command which is just an alias and will do the exact same thing:

rails s
Enter fullscreen mode Exit fullscreen mode

You should see something similar to this:

Rails server starting

By default, the server listens to port 3000 but you may change to the one you desire by using the -p option:

rails server -p 8080
Enter fullscreen mode Exit fullscreen mode

So, the web server started and our application is successfully deployed. Open your browser and visit the following address:

http://localhost:8080
Enter fullscreen mode Exit fullscreen mode

Tadaaa... You should see something like this:

Rails welcome aboard

Before we continue, I will try to explain in a simple way how a rails application works.

  • Every request to the application is served by methods (called actions) which are defined in special files called controllers.
  • These actions execute what has to be executed and define what the response will be (for example an html page, a JSON object etc). The responses (e.x. a page) are defined in special files called views but there are cases (such as when responding with a JSON object) that an action's view is not required to be "defined" (well, in such cases we say we have JSON views etc).
  • The rules (routes) that define which action of which controller will serve each request are placed in a special file called routes.rb

These are enough for the time being. Let's create our first controller named pages.
From the command line:

rails generate controller pages
Enter fullscreen mode Exit fullscreen mode

You will see a bunch of lines coming out from this command but focus on the first one:

Rails generating a controller

Yes, pages_controller.rb is our controller.
In this file we are going to create our action that will serve the "root" (home) request to our application.

So, open this file with your text editor. Its location is:
app/controllers/pages_controller.rb

As you can see, the controller is empty. We will add an action to it, let's call it home:

def home
end
Enter fullscreen mode Exit fullscreen mode

As you can see, our action does nothing since all we want to do is show a static page with text Hello world. Let's add something though just to see it being executed from the server's log:

class PagesController < ApplicationController
  def home
    puts "Hello console!"
  end
end
Enter fullscreen mode Exit fullscreen mode

If you speak Java, puts is similar to Java's System.out.println();

If not told otherwise (which is our case), the home action will try to respond with a view named home too.
So let's create this view in the appropriate folder which is:
app/views/pages/

Create a file in this folder with the name home.html.erb

The erb extension implies that this file will be processed by Rails in order to embed any dynamic content.

Edit this file and add:

<h1>Hello world!</h1>
Enter fullscreen mode Exit fullscreen mode

What's left? Yes, we must route the root requests to our controller's action.

Open with your text editor the routes.rb file which is located here:
config/routes.rb

You will find a bunch of help comments (text starting with #) there which you can delete.

Now, add the following line which tells that the root path / will be served by our controller's home action:

root to: 'pages#home'
Enter fullscreen mode Exit fullscreen mode

If you refresh your browser, you will see the amazing and super complex page we just created:

Hello world static page

We could stop here but it would be nice if we had the Hello world! text being passed to the view from the controller's action, yes? Yes.

Open the pages controller again and change the home action:

def home
  @greeting = "Home action says: Hello world!"
end
Enter fullscreen mode Exit fullscreen mode

Here, we declared an instance variable to our controller with name greeting and value Home action says: Hello world!.

This variable is available for use from our corresponding view so open the home.html.erb view and change its contents to the following:

<h1><%= @greeting %></h1>
Enter fullscreen mode Exit fullscreen mode

Refresh the page in your browser and there it is:

Hello world dynamic page

There, you just created your first Ruby on Rails application!


This post has been edited and re-posted here from my blog.

Top comments (2)

Collapse
 
karchana_06 profile image
Archana KN

I'm getting this error when started rails server.

Internal Server Error

Missing secret_token and secret_key_base for 'vagrant' environment, set these values in config/secrets.yml
WEBrick/1.3.1 (Ruby/2.1.5/2014-11-13) at localhost:3000

Collapse
 
iridakos profile image
Lazarus Lazaridis

Well that is strange... The only thing I can think of is that you start the server with the rails environment set to vagrant.

In which OS are you working on? Can you check if there is an environment variable with the name RAILS_ENV set to vagrant?