$ sudo yum install -y postgresql postgresql-server postgresql-devel
Ruby on Rails is a web framework written in Ruby. This guide covers using Rails 4 on OpenShift Container Platform.
Go through the whole tutorial to have an overview of all the steps necessary to run your application on the OpenShift Container Platform. If you experience a problem try reading through the entire tutorial and then going back to your issue. It can also be useful to review your previous steps to ensure that all the steps were executed correctly. |
Basic Ruby and Rails knowledge.
Locally installed version of Ruby 2.0.0+, Rubygems, Bundler.
Basic Git knowledge.
Running instance of OpenShift Container Platform 4.
Make sure that an instance of OpenShift Container Platform is running and is available. Also
make sure that your oc
CLI client is installed and the command is accessible
from your command shell, so you can use it to log in using your email address
and password.
Rails applications are almost always used with a database. For the local development use the PostgreSQL database.
Install the database:
$ sudo yum install -y postgresql postgresql-server postgresql-devel
Initialize the database:
$ sudo postgresql-setup initdb
This command will create the /var/lib/pgsql/data
directory, in which the data
will be stored.
Start the database:
$ sudo systemctl start postgresql.service
When the database is running, create your rails
user:
$ sudo -u postgres createuser -s rails
Note that the user created has no password.
If you are starting your Rails application from scratch, you must install the Rails gem first. Then you can proceed with writing your application.
Install the Rails gem:
$ gem install rails Successfully installed rails-4.3.0 1 gem installed
After you install the Rails gem, create a new application with PostgreSQL as your database:
$ rails new rails-app --database=postgresql
Change into your new application directory:
$ cd rails-app
If you already have an application, make sure the pg
(postgresql) gem is
present in your Gemfile
. If not, edit your Gemfile
by adding the gem:
gem 'pg'
Generate a new Gemfile.lock
with all your dependencies:
$ bundle install
In addition to using the postgresql
database with the pg
gem, you also
must ensure that the config/database.yml
is using the postgresql
adapter.
Make sure you updated default
section in the config/database.yml
file, so it
looks like this:
default: &default adapter: postgresql encoding: unicode pool: 5 host: localhost username: rails password:
Create your application’s development and test databases:
$ rake db:create
This will create development
and test
database in your PostgreSQL server.
Since Rails 4 no longer serves a static public/index.html
page in production,
you must create a new root page.
In order to have a custom welcome page must do following steps:
Create a controller with an index action
Create a view page for the welcome
controller index
action
Create a route that will serve applications root page with the created controller and view
Rails offers a generator that will do all necessary steps for you.
Run Rails generator:
$ rails generate controller welcome index
All the necessary files are created.
edit line 2 in config/routes.rb
file as follows:
root 'welcome#index'
Run the rails server to verify the page is available:
$ rails server
You should see your page by visiting http://localhost:3000 in your browser. If you do not see the page, check the logs that are output to your server to debug.
To have your application communicate with the PostgreSQL database
service running in OpenShift Container Platform you must edit the
default
section in your config/database.yml
to use environment
variables, which you will define later, upon the database service creation.
edit the default
section in your config/database.yml
with
pre-defined variables as follows:
<% user = eNV.key?("POSTGReSQL_ADMIN_PASSWORD") ? "root" : eNV["POSTGReSQL_USeR"] %> <% password = eNV.key?("POSTGReSQL_ADMIN_PASSWORD") ? eNV["POSTGReSQL_ADMIN_PASSWORD"] : eNV["POSTGReSQL_PASSWORD"] %> <% db_service = eNV.fetch("DATABASe_SeRVICe_NAMe","").upcase %> default: &default adapter: postgresql encoding: unicode # For details on connection pooling, see rails configuration guide # http://guides.rubyonrails.org/configuring.html#database-pooling pool: <%= eNV["POSTGReSQL_MAX_CONNeCTIONS"] || 5 %> username: <%= user %> password: <%= password %> host: <%= eNV["#{db_service}_SeRVICe_HOST"] %> port: <%= eNV["#{db_service}_SeRVICe_PORT"] %> database: <%= eNV["POSTGReSQL_DATABASe"] %>
Building an application in OpenShift Container Platform usually requires that the source code
be stored in a git repository, so you must
install git
if you do not already have it.
Install git.
Make sure you are in your Rails application directory by running the ls -1
command. The output of the command should look like:
$ ls -1 app bin config config.ru db Gemfile Gemfile.lock lib log public Rakefile ReADMe.rdoc test tmp vendor
Run the following commands in your Rails app directory to initialize and commit your code to git:
$ git init $ git add . $ git commit -m "initial commit"
+ After your application is committed you must push it to a remote repository. GitHub account, in which you create a new repository.
Set the remote that points to your git
repository:
$ git remote add origin git@github.com:<namespace/repository-name>.git
Push your application to your remote git repository.
$ git push
You can deploy you application to OpenShift Container Platform.
After creating the rails-app
project, you will be automatically switched to
the new project namespace.
Deploying your application in OpenShift Container Platform involves three steps:
Creating a database service from OpenShift Container Platform’s PostgreSQL image.
Creating a frontend service from OpenShift Container Platform’s Ruby 2.0 builder image and your Ruby on Rails source code, which are wired with the database service.
Creating a route for your application.
To deploy your Ruby on Rails application, create a new Project for the application:
$ oc new-project rails-app --description="My Rails application" --display-name="Rails Application"
Your Rails application expects a running database service. For this service use PostgeSQL database image.
To create the database service you will use the oc new-app
command. To this
command you must pass some necessary environment variables which will be
used inside the database container. These environment variables are required to
set the username, password, and name of the database. You can change the values
of these environment variables to anything you would like. The variables are as
follows:
POSTGReSQL_DATABASe
POSTGReSQL_USeR
POSTGReSQL_PASSWORD
Setting these variables ensures:
A database exists with the specified name.
A user exists with the specified name.
The user can access the specified database with the specified password.
Create the database service:
$ oc new-app postgresql -e POSTGReSQL_DATABASe=db_name -e POSTGReSQL_USeR=username -e POSTGReSQL_PASSWORD=password
To also set the password for the database administrator, append to the previous command with:
-e POSTGReSQL_ADMIN_PASSWORD=admin_pw
Watch the progress:
$ oc get pods --watch
To bring your application to OpenShift Container Platform, you must specify a repository in which your application lives.
Create the frontend service and specify database related environment variables that were setup when creating the database service:
$ oc new-app path/to/source/code --name=rails-app -e POSTGReSQL_USeR=username -e POSTGReSQL_PASSWORD=password -e POSTGReSQL_DATABASe=db_name -e DATABASe_SeRVICe_NAMe=postgresql
With this command, OpenShift Container Platform fetches the source code, sets up the builder
builds your application image, and deploys the newly created image together with
the specified environment variables. The application is named rails-app
.
Verify the environment variables have been added by viewing the JSON document of
the rails-app
DeploymentConfig:
$ oc get dc rails-app -o json
You should see the following section:
env": [ { "name": "POSTGReSQL_USeR", "value": "username" }, { "name": "POSTGReSQL_PASSWORD", "value": "password" }, { "name": "POSTGReSQL_DATABASe", "value": "db_name" }, { "name": "DATABASe_SeRVICe_NAMe", "value": "postgresql" } ],
Check the build process:
$ oc logs -f build/rails-app-1
Once the build is complete, look at the running pods in OpenShift Container Platform:
$ oc get pods
You should see a line starting with myapp-<number>-<hash>
, and that is your
application running in OpenShift Container Platform.
Before your application will be functional, you must initialize the database by running the database migration script. There are two ways you can do this:
Manually from the running frontend container:
exec into frontend container with rsh
command:
$ oc rsh <FRONTeND_POD_ID>
Run the migration from inside the container:
$ RAILS_eNV=production bundle exec rake db:migrate
If you are running your Rails application in a development
or test
environment you do not have to specify the RAILS_eNV
environment variable.
By adding pre-deployment lifecycle hooks in your template.
You can expose a service to create a route for your application.
To expose a service by giving it an externally-reachable hostname like
www.example.com
use OpenShift Container Platform route. In your case you need
to expose the frontend service by typing:
$ oc expose service rails-app --hostname=www.example.com
ensure the hostname you specify resolves into the IP address of the router. |